Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Fehlermeldung, die ich nicht verstehe... [gelöst]

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Fehlermeldung, die ich nicht verstehe... [gelöst]

    This topic has been deleted. Only users with topic management privileges can see it.
    • Andreios
      Andreios Forum Testing @paul53 last edited by

      @paul53 sagte in Fehlermeldung, die ich nicht verstehe...:

      @skorpil sagte: Ich erhalte diesen Hinweis/ Fehlermeldung

      Ignorieren!

      Das ist aber eine echt erschöpfende Antwort! 🤦‍♂️
      Mich würde schon interessieren, warum diese Meldung erscheint und warum er sie ignorieren soll.

      1 Reply Last reply Reply Quote 0
      • Armilar
        Armilar Most Active Forum Testing @skorpil last edited by

        @skorpil sagte in Fehlermeldung, die ich nicht verstehe...:

        Ich erhalte diesen Hinweis/ Fehlermeldung

        Cannot redeclare block-scoped variable 'IDklingelsensor'.(2451)
        index0.js(6, 7): 'IDklingelsensor' was also declared here.
        

        im folgenden Script

        // ##################################
        // Deklarationen
        // ##################################
        
        var sperre = false;
        const IDklingelsensor = 'hm-rpc.0.MEQ0656853.1.PRESS_SHORT'/*Klingelsensor Trepph :1 PRESS SHORT*/;
        
        // ##################################
        // Programm
        // ##################################
        
        on({id: IDklingelsensor}, function (data) {
            if (data.state.val = true) {
                
                if(!sperre) {
                sperre = true;
        
                //Ansagetext
                const text = "Es klingelt an der neuen Haustür unten";
                //log("läuft");
                
                // Badezimmer 
                setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak-volume'/*Volume to use for speak commands*/, 100)
                setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak'/*speak*/, text);
                setTimeout(function() {
                }, 1000);
            
                // Buero;
                setState('alexa2.0.Echo-Devices.G090XG1215160GQD.Commands.speak-volume'/*Volume to use for speak commands*/, 100)
                setState('alexa2.0.Echo-Devices.G090XG1215160GQD.Commands.speak'/*speak*/, text);
                setTimeout(function() {
                }, 1000); 
            
                // Kueche;
                setState('alexa2.0.Echo-Devices.G090LF0965231J5Q.Commands.speak-volume'/*Volume to use for speak commands*/, 100)
                setState('alexa2.0.Echo-Devices.G090LF0965231J5Q.Commands.speak'/*speak*/, text);
                setTimeout(function() {
                }, 1000);
            
                // Wohnzimmer;
                setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak-volume'/*Volume to use for speak commands*/, 100)
                setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak'/*speak*/, text);
            
                setTimeout(function() {
                sperre = false;
                }, 5000); 
            }
        }      
        });
        
        

        Mit diesem Script will ich erreichen, daß die Amazone Echo Devises in den verschiedenen Räumen eine Ansage ausgeben, wenn der Klingelsensor ein Klingeln an der jeweiligen Haustüre detektiert.

        Ich benutze das Script in Modifikationen dreimal, je nach dem an welcher Türe es klingelt. Liegt der Fehler daran, dass die "const" Definition in allen Scripten unterschiedlich ist? Hier brauche ich vielleicht ein wenig Nachhilfe. Dankeschön.

        Was passiert, wenn die Zeile 12 so aussieht?

        on({id: IDklingelsensor, change: "ne"}, async function (data) {
        
        1 Reply Last reply Reply Quote 0
        • mcm1957
          mcm1957 last edited by

          @skorpil
          Du schreibst du hast das Script 3x.

          Ich gehe v´mal davon aus es geht im Script im Script Adapter (und nicht um Adapterprogrammierung)

          Kann es sein, dass du das Script im Ordner GLOBAL abgelegt hast? Dann würden nämlich - wenn ich es richtig im Kopf habe - alle 3 Varianten geladen was die Fehlermeldung ev. erklären könnte.

          https://forum.iobroker.net/topic/2241/scripteditor-unterschied-zwischen-common-global

          paul53 OliverIO S 3 Replies Last reply Reply Quote 1
          • paul53
            paul53 @mcm1957 last edited by

            @mcm57 sagte: Script im Ordner GLOBAL abgelegt hast? Dann würden nämlich - wenn ich es richtig im Kopf habe - alle 3 Varianten geladen was die Fehlermeldung ev. erklären könnte.

            Das würde die Fehlermeldung des Editors nicht erklären, da die globalen Skripte erst bei Skriptstart in das startende Skript geladen werden.

            mcm1957 1 Reply Last reply Reply Quote 1
            • mcm1957
              mcm1957 @paul53 last edited by

              @paul53
              OK und sorry,
              hab nicht überzuckert dass die Meldung schon im Editor kommt und nicht erst zur Laufzeit.

              Wüsste aber dann nicht, inwiefern deine Vermutung dass es an den drei nahezu identen Scripts liegen könnte zutreffen könnte. Der Editor kann ja kaum wissen, dass es noch andere Scripte am System gibt - oder ?

              Bin mal gespannt ob ein erfahrenerer Scripter da was sieht.

              McM

              1 Reply Last reply Reply Quote 1
              • OliverIO
                OliverIO @mcm1957 last edited by OliverIO

                @mcm57

                das wäre jetzt auch mein tip.
                du hast die variable bereits in einem global-skript definiert.

                hat zwar mit dem Fehler nix zu tun, aber diese Anweisungen machen keinen Sinn

                        setTimeout(function() {
                        }, 1000); 
                

                wenn du sie später noch füllen willst, gut,
                dann würde aber eine auch reichen.

                und noch ein Fehler
                du willst doch sicherlich vergleichen?
                So weist du aber ein true zu.
                zum vergleichen benötigst du ==

                    if (data.state.val = true) {
                

                der nachfolgende teil wird dann immer ausgeführt, da eine Zuweisung immer den zugewiesenen wert zurückgibt und daher ist hier immer alles true

                und mit dem einrücken stimmt hier was nicht
                das macht den code schwer lesbar

                so müsste es richtig aussehen

                
                // ##################################
                // Deklarationen
                // ##################################
                
                var sperre = false;
                const IDklingelsensor = 'hm-rpc.0.MEQ0656853.1.PRESS_SHORT' /*Klingelsensor Trepph :1 PRESS SHORT*/;
                
                // ##################################
                // Programm
                // ##################################
                
                on({
                    id: IDklingelsensor
                }, function (data) {
                    if (data.state.val = true) {
                
                        if (!sperre) {
                            sperre = true;
                
                            //Ansagetext
                            const text = "Es klingelt an der neuen Haustür unten";
                            //log("läuft");
                
                            // Badezimmer
                            setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak-volume' /*Volume to use for speak commands*/, 100)
                            setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak' /*speak*/, text);
                            setTimeout(function () {}, 1000);
                
                            // Buero;
                            setState('alexa2.0.Echo-Devices.G090XG1215160GQD.Commands.speak-volume' /*Volume to use for speak commands*/, 100)
                            setState('alexa2.0.Echo-Devices.G090XG1215160GQD.Commands.speak' /*speak*/, text);
                            setTimeout(function () {}, 1000);
                
                            // Kueche;
                            setState('alexa2.0.Echo-Devices.G090LF0965231J5Q.Commands.speak-volume' /*Volume to use for speak commands*/, 100)
                            setState('alexa2.0.Echo-Devices.G090LF0965231J5Q.Commands.speak' /*speak*/, text);
                            setTimeout(function () {}, 1000);
                
                            // Wohnzimmer;
                            setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak-volume' /*Volume to use for speak commands*/, 100)
                            setState('alexa2.0.Echo-Devices.G090LF09716403QV.Commands.speak' /*speak*/, text);
                
                            setTimeout(function () {
                                sperre = false;
                            }, 5000);
                        }
                    }
                });
                
                
                S 2 Replies Last reply Reply Quote 0
                • paul53
                  paul53 @skorpil last edited by paul53

                  @skorpil sagte:

                  on({id: IDklingelsensor}, function (data) {
                      if (data.state.val = true) {
                  

                  Das ersetze besser durch

                  on({id: IDklingelsensor, val: true}, function () {
                  
                  S 1 Reply Last reply Reply Quote 0
                  • S
                    skorpil @mcm1957 last edited by

                    @mcm57

                    Danke für den Hinweis. Richtig, es geht nicht um eine Adapterprogrammierung, sondern um ein Script im Script Adapter.

                    Ich bin nicht sicher, ob das der Ordner GLOBAL ist. Hier ein Screenshot

                    Baum.jpg

                    Alle meine Scripte stehen nicht unter "common", sondern ich habe im Stammverzeichnis Unterordner angelegt. Vielleicht ist das nicht richtig. Was sollte ich tun?

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @skorpil last edited by

                      @skorpil sagte: im Stammverzeichnis Unterordner angelegt. Vielleicht ist das nicht richtig.

                      Das ist in Ordnung.

                      1 Reply Last reply Reply Quote 0
                      • S
                        skorpil @OliverIO last edited by

                        @oliverio

                        1. Ich habe eben einen Screenshot gepostet. Wenn der Fehler tatsächlich durch Vewendung des "GLOBAL" entsteht, reich es dann, sie in common zu verschieben? Oder was ist Dein Rat?

                        2. beim Timeout habe ich vermutlich falsch programmiert. Ich wollte eigentlich nur eine Pause von einer Sekunde einbauen, bevor der nächste Teil aufgerufen wird. Wie wäre das richtig?

                        3. ich schaue mir das mit dem "==" an und werde es korrigieren.

                        4. ...ebenso das Einrücken

                        Vielen Dank, ich sehe, ich muß viel lernen...

                        paul53 1 Reply Last reply Reply Quote 0
                        • S
                          skorpil @paul53 last edited by

                          @paul53 sagte in Fehlermeldung, die ich nicht verstehe...:

                          @skorpil sagte:

                          on({id: IDklingelsensor}, function (data) {
                              if (data.state.val = true) {
                          

                          Das ersetze besser durch

                          on({id: IDklingelsensor, val: true}, function () {
                          

                          werde ich mörgen testen. Danke

                          1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 @skorpil last edited by

                            @skorpil sagte: eine Pause von einer Sekunde einbauen, bevor der nächste Teil aufgerufen wird. Wie wäre das richtig?

                            await wait(1000);
                            
                            S 2 Replies Last reply Reply Quote 1
                            • S
                              skorpil @OliverIO last edited by

                              @oliverio sagte in Fehlermeldung, die ich nicht verstehe...:

                              das wäre jetzt auch mein tip.
                              du hast die variable bereits in einem global-skript definiert.

                              lt. paul53 scheine ich das mit den Ordnern richtig gemacht zu haben. Was ist dann falsch. Bin verwirrt.

                              paul53 1 Reply Last reply Reply Quote 0
                              • S
                                skorpil @paul53 last edited by

                                @paul53

                                so einfach, daaaanke

                                1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 @skorpil last edited by

                                  @skorpil sagte: Was ist dann falsch. Bin verwirrt.

                                  Wie schon geschrieben: Ignorieren! Manchmal liefert die Syntaxprüfung des Editors Fehler, die keine sind.

                                  1 Reply Last reply Reply Quote 1
                                  • S
                                    skorpil last edited by

                                    Ich werde morgen mal die ganzen Hinweise, für die ich sehr dankbar bin, einbauen und schauen, was passiert. Danach poste ich das überarbeitete Script noch mal. Danke Euch allen.

                                    OliverIO 1 Reply Last reply Reply Quote 0
                                    • OliverIO
                                      OliverIO @skorpil last edited by OliverIO

                                      @skorpil
                                      ja seltsam.
                                      so wie es aussieht hast du den global ordner nicht mal eingeblendet (expertenansicht).
                                      dann wird es so sein, das es ein problem mit der syntaxprüfung ist

                                      wenn ich das skript allerdings bei mir einfüge, wird nicht gemeckert.

                                      S 2 Replies Last reply Reply Quote 1
                                      • S
                                        skorpil @OliverIO last edited by

                                        @oliverio Danke für den Hinweis. Ich wusste nicht mal, dass man in der Expertenansicht global an und ausschaltet. Wieder was gelernt…

                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          skorpil @OliverIO last edited by

                                          @oliverio …sehr merkwürdig: jetzt habe ich mal den Expertenmodus aus- und wieder eingeschaltet. Jetzt wird der leere Ordner „global“ angezeigt. Er verschwindet aber auch nicht wieder…sollte er im Expertenmodus zu sehen sein oder umgekehrt?

                                          OliverIO 1 Reply Last reply Reply Quote 0
                                          • OliverIO
                                            OliverIO @skorpil last edited by

                                            @skorpil

                                            im expertenmodus sichtbar
                                            ohne sollte er ausgeblendet sein
                                            also das
                                            kopficon grün ist expertenmodus
                                            kopficon weiß ist normal

                                            S 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            712
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            29
                                            1200
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo