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.
    • 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
          • S
            skorpil @OliverIO last edited by skorpil

            @oliverio

            Offenbar spinnt meine Installation. Jetzt ist der Ordner immer da, egal ob Expertenmodus oder nicht.

            B0E38C4D-0669-470C-B3B5-DD0A78D916A5.jpeg

            ECE6DA22-6AC9-4AB6-BF18-9E32E80E4D64.jpeg

            Auch neu laden der Website bringt keine Veränderung.

            Danke für die Hilfe. Ich melde mich morgen….

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

              @skorpil
              wenn er leer ist, ist das nicht so schlimm.
              mach mal ctrl+reload knopf im browser
              dadurch wird der cache geleert.
              evtl hängt es daran

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

                @paul53 @OliverIO

                So, jetzt habe ich das Script entsprechend Euren Vorschlägen angepasst:

                1. die On Anweisung habe ich angepasst (womit vermutlich die If Anweisung mit der falschen Zuweisung "=", statt dem richtigen Vergleich mit "==" entfällt,
                2. das Einrücken ebenfalls
                3. die await Funktion (die mir noch Sorgen macht)
                
                 // ##################################
                // Deklarationen
                // ##################################
                 
                var sperre = false;
                const IDklingelsensor = 'hm-rpc.0.MEQ0656853.1.PRESS_SHORT' /*Klingelsensor Trepph :1 PRESS SHORT*/;
                 
                // ##################################
                // Programm
                // ##################################
                 
                on({
                    id: IDklingelsensor, val: true
                }, function () {
                 
                        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);
                            await wait(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);
                            await wait(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);
                            await wait(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);
                        }
                    }
                });
                
                

                Ich bekomme nun eine Fehlermeldung in Zeile 27.

                javascript.0 (20957) script.js.Alexa.Überarbeitet compile failed: at script.js.Alexa.Überarbeitet:27
                

                Offenbar habe ich den Hinweis von @paul53 falsch interpretiert, wie man die Pause von 1 Sekunde implementiert. Wie wäre es denn richtig?

                paul53 OliverIO 2 Replies Last reply Reply Quote 0
                • paul53
                  paul53 @skorpil last edited by

                  @skorpil sagte: die await Funktion (die mir noch Sorgen macht)

                  Ach ja: Wenn man await verwendet, muss man die Funktion als "async" deklarieren:

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

                    @skorpil

                    wenn await verwendet wird, muss du umschließende Funktion mit async markiert werden
                    und wegen einrücken und so, die letzte geschweifte Klammer war überflüssig
                    und am Ende der setState-Zeilen fehlen semicolons (;). ist zwar kein direkter Fehler, kann aber in bestimmten Konstellationen dazu führen, das der Interpreter was anderes macht was du denkst
                    https://betterprogramming.pub/the-use-of-the-javascript-semicolon-843fd5e94d0e

                     
                     // ##################################
                    // Deklarationen
                    // ##################################
                     
                    var sperre = false;
                    const IDklingelsensor = '0_userdata.0.test1' /*Klingelsensor Trepph :1 PRESS SHORT*/;
                     
                    // ##################################
                    // Programm
                    // ##################################
                     
                    on({
                        id: IDklingelsensor, val: true
                    }, async function () {
                     
                            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);
                                
                     
                                // 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);
                                await wait(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);
                                await wait(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 1 Reply Last reply Reply Quote 1
                    • S
                      skorpil @OliverIO last edited by skorpil

                      @oliverio @paul53

                      Ihr seid der Hammer! Super, Danke, läuft!!!

                      Wenn jetzt an der Haustür geklingelt wird, sagt mir die Amazon Alexa (Echos) in den verschiedenen Räumen an, daß und wo geklingelt wurde.

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

                        @skorpil
                        sehr schön

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        748
                        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