Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [gelöst] auf globale Objekt kann nicht zugegriffen werden

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    823

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    6.3k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.6k

[gelöst] auf globale Objekt kann nicht zugegriffen werden

Scheduled Pinned Locked Moved JavaScript
52 Posts 5 Posters 1.4k Views 3 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • haus-automatisierungH haus-automatisierung

    @ticaki Logisch, ist bis dato nur scheinbar niemandem aufgefallen (bzw. wurde nicht gemeldet)

    Ben1983B Offline
    Ben1983B Offline
    Ben1983
    wrote on last edited by
    #32

    @haus-automatisierung irgendwie will es heute nicht...

    wieso bekomme ich jetzt keinen Log?

    log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
    
    onMessage("Testmessage",(messagedata,callback) =>{
        const myData = {input: messagedata,
                        output:{name:"Test"}};
        callback(myData)
    });
    
    T 1 Reply Last reply
    0
    • haus-automatisierungH haus-automatisierung

      @ticaki Logisch, ist bis dato nur scheinbar niemandem aufgefallen (bzw. wurde nicht gemeldet)

      T Do not disturb
      T Do not disturb
      ticaki
      wrote on last edited by
      #33

      @haus-automatisierung
      Wäre mir wohl so auch nicht klar gewesen aber erste habe ich wegen hängendem sendToAsync im Adapter erfahren dass es da keinen default timeout gibt. Und 2 Tage später fliegen die Leitungen von meinem Boiler und 4 Stunden vorher haben die Logeinträge meines Warmwasserskripts geendet. Da war der Zusammenhang nicht schwer herzustellen. Mist nur das die Überhitzungssicherheitsschaltung zu alt/ kaputt war. Naja, war zum Glück nur ne Riesensauerei.

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      1 Reply Last reply
      0
      • Ben1983B Ben1983

        @haus-automatisierung irgendwie will es heute nicht...

        wieso bekomme ich jetzt keinen Log?

        log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
        
        onMessage("Testmessage",(messagedata,callback) =>{
            const myData = {input: messagedata,
                            output:{name:"Test"}};
            callback(myData)
        });
        
        T Do not disturb
        T Do not disturb
        ticaki
        wrote on last edited by ticaki
        #34

        @ben1983

        Das await müsste bei dir eigentlich als Fehler markiert sein.

        test()
        
        async function test() {
            log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:10000})));
        }
         
        onMessage("Testmessage",(messagedata,callback) =>{
            const myData = {input: messagedata,
                            output:{name:"Test"}};
            callback(myData)
        });
        

        Ach und mit abgestürzter Javascriptinstanze gibts keine logs :D

        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

        Spenden

        Ben1983B 1 Reply Last reply
        0
        • haus-automatisierungH haus-automatisierung

          @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

          Beim Verwendet von messageToAsynch tritt dieser Fehler auf:

          Ist wohl nen Bug wenn die Options fehlen. So gehts:

          const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
          console.log(JSON.stringify(res));
          

          Machst einen GitHub Issue?

          Ben1983B Offline
          Ben1983B Offline
          Ben1983
          wrote on last edited by
          #35

          @haus-automatisierung erledigt:
          https://github.com/ioBroker/ioBroker.javascript/issues/1437

          1 Reply Last reply
          0
          • T ticaki

            @ben1983

            Das await müsste bei dir eigentlich als Fehler markiert sein.

            test()
            
            async function test() {
                log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:10000})));
            }
             
            onMessage("Testmessage",(messagedata,callback) =>{
                const myData = {input: messagedata,
                                output:{name:"Test"}};
                callback(myData)
            });
            

            Ach und mit abgestürzter Javascriptinstanze gibts keine logs :D

            Ben1983B Offline
            Ben1983B Offline
            Ben1983
            wrote on last edited by Ben1983
            #36

            @ticaki ok und woran liegt es?
            Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
            Woran liegt jetzt der Fehler?
            Habe ich was übersehen?

            @haus-automatisierung kannst Du mir sagen, warum es nicht geht?

            bei deinem Beispeil:

            const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
            console.log(JSON.stringify(res));
            

            meckert er bei mir genauso das await an.

            T 1 Reply Last reply
            0
            • Ben1983B Ben1983

              @ticaki ok und woran liegt es?
              Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
              Woran liegt jetzt der Fehler?
              Habe ich was übersehen?

              @haus-automatisierung kannst Du mir sagen, warum es nicht geht?

              bei deinem Beispeil:

              const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
              console.log(JSON.stringify(res));
              

              meckert er bei mir genauso das await an.

              T Do not disturb
              T Do not disturb
              ticaki
              wrote on last edited by ticaki
              #37

              @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

              @ticaki ok und woran liegt es?
              Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
              Woran liegt jetzt der Fehler?
              Habe ich was übersehen?

              Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

              Bildschirmfoto 2023-11-06 um 13.31.45.png

              EDIT:
              Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

              Spenden

              Ben1983B 2 Replies Last reply
              0
              • T ticaki

                @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                @ticaki ok und woran liegt es?
                Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                Woran liegt jetzt der Fehler?
                Habe ich was übersehen?

                Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

                Bildschirmfoto 2023-11-06 um 13.31.45.png

                EDIT:
                Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

                Ben1983B Offline
                Ben1983B Offline
                Ben1983
                wrote on last edited by
                #38

                @ticaki ja bei mir auch, aber warum?

                T 1 Reply Last reply
                0
                • T ticaki

                  @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                  @ticaki ok und woran liegt es?
                  Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                  Woran liegt jetzt der Fehler?
                  Habe ich was übersehen?

                  Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

                  Bildschirmfoto 2023-11-06 um 13.31.45.png

                  EDIT:
                  Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

                  Ben1983B Offline
                  Ben1983B Offline
                  Ben1983
                  wrote on last edited by
                  #39

                  @ticaki selbst so geht es nicht:

                  const ausgabe = await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})
                  log(ausgabe);
                  
                  1 Reply Last reply
                  0
                  • Ben1983B Ben1983

                    @ticaki ja bei mir auch, aber warum?

                    T Do not disturb
                    T Do not disturb
                    ticaki
                    wrote on last edited by
                    #40

                    @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                    @ticaki ja bei mir auch, aber warum?

                    Hab ich doch oben geschrieben? Await setzt async voraus. Du kannst nur in einem asynchron laufenden Programmteil warten. Sonst würde ja der ganze Javascript-Adapter warten oder ist es der ganze Iobroker :)

                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                    Spenden

                    1 Reply Last reply
                    0
                    • Ben1983B Offline
                      Ben1983B Offline
                      Ben1983
                      wrote on last edited by Ben1983
                      #41

                      @ticaki OK. jetzt weiß ich was Du meinst.
                      Ich muss also um das ausführen zu können quasi so ein Konstrukt erstellen:

                      async function myDummy(){
                          log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
                      }
                      myDummy();
                      onMessage("Testmessage",(messagedata,callback) =>{
                          const myData = {input: messagedata,
                                          output:{name:"Test"}};
                          callback(myData)
                      });
                      

                      @haus-automatisierung dann könnte ich ja nirgends in bspw. einem on(.... eine await messageToAsync nutzen, um gewisse Rückmeldungen zu bekommen.
                      ist ja nicht innerhalb einer async funktion

                      T 1 Reply Last reply
                      0
                      • paul53P paul53

                        @ben1983 sagte: "Besser" das Objekt nur dazu definieren, wo es gebraucht wird?

                        Ja. Die Gruppe "global" verwendet man für häufig verwendete eigene Funktionen.
                        Mit globalen Objektdefinitionen müllt man sich den RAM der Javascript-Instanz zu, da sie in jedem nicht globalen Skript kompiliert werden.

                        Ben1983B Offline
                        Ben1983B Offline
                        Ben1983
                        wrote on last edited by
                        #42

                        @paul53 Ich nutze es aktuell hauptsächlich um ids in eine Variable zu speichern und dann komplett in allen skripten darauf zugreifen zu können.
                        Wenn sich sonst was ändert, müsste ich überall die id nachziehen. deshalb war es so gedacht.
                        Oder gibts ne andere bessere Lösung?

                        paul53P 1 Reply Last reply
                        0
                        • Ben1983B Ben1983

                          @paul53 Ich nutze es aktuell hauptsächlich um ids in eine Variable zu speichern und dann komplett in allen skripten darauf zugreifen zu können.
                          Wenn sich sonst was ändert, müsste ich überall die id nachziehen. deshalb war es so gedacht.
                          Oder gibts ne andere bessere Lösung?

                          paul53P Offline
                          paul53P Offline
                          paul53
                          wrote on last edited by
                          #43

                          @ben1983 sagte: Wenn sich sonst was ändert, müsste ich überall die id nachziehen.

                          Dafür sind eigentlich Alias-DP gedacht, damit man man nur an einer Stelle bei Veränderungen anpassen muss.

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          Ben1983B 1 Reply Last reply
                          0
                          • Ben1983B Ben1983

                            @ticaki OK. jetzt weiß ich was Du meinst.
                            Ich muss also um das ausführen zu können quasi so ein Konstrukt erstellen:

                            async function myDummy(){
                                log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
                            }
                            myDummy();
                            onMessage("Testmessage",(messagedata,callback) =>{
                                const myData = {input: messagedata,
                                                output:{name:"Test"}};
                                callback(myData)
                            });
                            

                            @haus-automatisierung dann könnte ich ja nirgends in bspw. einem on(.... eine await messageToAsync nutzen, um gewisse Rückmeldungen zu bekommen.
                            ist ja nicht innerhalb einer async funktion

                            T Do not disturb
                            T Do not disturb
                            ticaki
                            wrote on last edited by
                            #44

                            @ben1983

                            Ja kannst du so nennen. Meine neueren Skripts sehen im Aufbau immer so aus:

                            const DEBUG = false
                            const cState = 'hier die id vom datenpunkt'
                            
                            var globaleVariable = 'irgendwas'
                            
                            async function main() {
                                // hier gehts los
                            }
                            
                            log('blabla started! und dann irgendwelche sinnvollen Daten die man wissen will')
                            main()
                            // hier kommt nix mehr
                            

                            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                            Spenden

                            1 Reply Last reply
                            0
                            • paul53P paul53

                              @ben1983 sagte: Wenn sich sonst was ändert, müsste ich überall die id nachziehen.

                              Dafür sind eigentlich Alias-DP gedacht, damit man man nur an einer Stelle bei Veränderungen anpassen muss.

                              Ben1983B Offline
                              Ben1983B Offline
                              Ben1983
                              wrote on last edited by
                              #45

                              @paul53 genau. und ich habe die Alias ids den variablen zugewiesen.

                              Fand es vom Code her schöner, nicht überall die id als string ein zu tragen. Oder?
                              Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.
                              Das wäre ja noch so ein machbarer mittelweg, oder wie siehst Du das?

                              paul53P 1 Reply Last reply
                              0
                              • Ben1983B Ben1983

                                @paul53 genau. und ich habe die Alias ids den variablen zugewiesen.

                                Fand es vom Code her schöner, nicht überall die id als string ein zu tragen. Oder?
                                Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.
                                Das wäre ja noch so ein machbarer mittelweg, oder wie siehst Du das?

                                paul53P Offline
                                paul53P Offline
                                paul53
                                wrote on last edited by
                                #46

                                @ben1983 sagte: Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.

                                So mache ich es.

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                Ben1983B 1 Reply Last reply
                                0
                                • paul53P paul53

                                  @ben1983 sagte: Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.

                                  So mache ich es.

                                  Ben1983B Offline
                                  Ben1983B Offline
                                  Ben1983
                                  wrote on last edited by
                                  #47

                                  @paul53 dann eben zur not an 1-x scripten ... oder wie?

                                  paul53P 1 Reply Last reply
                                  0
                                  • Ben1983B Ben1983

                                    @paul53 dann eben zur not an 1-x scripten ... oder wie?

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by paul53
                                    #48

                                    @ben1983 sagte: dann eben zur not an 1-x scripten ... oder wie?

                                    Ja, denn x Skripte mit den zugehörigen Konstanten-Definitionen zu Beginn ist besser als alle Skripte mit allen Definitionen aus "global".

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    1 Reply Last reply
                                    0
                                    • T Do not disturb
                                      T Do not disturb
                                      ticaki
                                      wrote on last edited by ticaki
                                      #49

                                      Ich versuche immer mehr von Datenpunkten weg zu kommen und alles auf Funktionen, Räume, Rolen mit Selektoren umzustellen.

                                      z.B.:

                                      anstatt:

                                      on({id:'hm-rpc.1.001A5D899A80FF.2.PRESS_SHORT', change:'any'}, (obj) =>
                                      {
                                           setState('lampe.im.bad', true); 
                                      })
                                      

                                      dann

                                      on({id:'hm-rpc.1.001A5D899A80FF.2.PRESS_SHORT', change:'any'}, (obj) =>
                                      {
                                          $('state(functions="beleuchtung")(rooms="Haus.second_floor.badezimmer")').each(id=> {setState(id, true);}) 
                                      })
                                      

                                      hab mir aber noch nicht überlegt wie ich die Schalter am besten vertagge :)

                                      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                      Spenden

                                      Ben1983B 1 Reply Last reply
                                      0
                                      • T ticaki

                                        Ich versuche immer mehr von Datenpunkten weg zu kommen und alles auf Funktionen, Räume, Rolen mit Selektoren umzustellen.

                                        z.B.:

                                        anstatt:

                                        on({id:'hm-rpc.1.001A5D899A80FF.2.PRESS_SHORT', change:'any'}, (obj) =>
                                        {
                                             setState('lampe.im.bad', true); 
                                        })
                                        

                                        dann

                                        on({id:'hm-rpc.1.001A5D899A80FF.2.PRESS_SHORT', change:'any'}, (obj) =>
                                        {
                                            $('state(functions="beleuchtung")(rooms="Haus.second_floor.badezimmer")').each(id=> {setState(id, true);}) 
                                        })
                                        

                                        hab mir aber noch nicht überlegt wie ich die Schalter am besten vertagge :)

                                        Ben1983B Offline
                                        Ben1983B Offline
                                        Ben1983
                                        wrote on last edited by
                                        #50

                                        @ticaki ok... bei mehreren Lampen im Raum, die einzeln angeschaltet werden, aber nicht so einfach machbar, oder man müsste unterräume haben.

                                        T 1 Reply Last reply
                                        0
                                        • Ben1983B Ben1983

                                          @ticaki ok... bei mehreren Lampen im Raum, die einzeln angeschaltet werden, aber nicht so einfach machbar, oder man müsste unterräume haben.

                                          T Do not disturb
                                          T Do not disturb
                                          ticaki
                                          wrote on last edited by ticaki
                                          #51

                                          @ben1983
                                          Die Szenen Schaltung im Wohnzimmer hab ich so auch noch nicht umgebaut. Aber ich hab mal mit jemandem hier diskutiert, der hatte sich eine Zusätzliiche Enum mit abend, morgens, usw gebaut und über diese Selektoren tagesabhängig die Lampen geschaltet.

                                          Bei Szennen würde ich wohl auch ne zusätzliche Enum machen

                                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                          Spenden

                                          Ben1983B 1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          296

                                          Online

                                          32.8k

                                          Users

                                          82.7k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe