Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [gelöst] Was ist der Scriptcontext?

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

[gelöst] Was ist der Scriptcontext?

Geplant Angeheftet Gesperrt Verschoben JavaScript
14 Beiträge 2 Kommentatoren 753 Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Great SUNG Offline
    Great SUNG Offline
    Great SUN
    schrieb am zuletzt editiert von Great SUN
    #1

    Hi Ihr,

    ich möchte eine function aus einem meiner JavaScript Scripte an eine externe Methode als Callback übergeben.
    Dazu muss ich die function an den Context binden (myfunction.bind(myContext)).

    Leider hab ich keine Ahnung, welches der Context ist.

    Kann mir da einer von Euch bitte helfen?

    Danke!

    OliverIOO 1 Antwort Letzte Antwort
    0
    • Great SUNG Great SUN

      Hi Ihr,

      ich möchte eine function aus einem meiner JavaScript Scripte an eine externe Methode als Callback übergeben.
      Dazu muss ich die function an den Context binden (myfunction.bind(myContext)).

      Leider hab ich keine Ahnung, welches der Context ist.

      Kann mir da einer von Euch bitte helfen?

      Danke!

      OliverIOO Offline
      OliverIOO Offline
      OliverIO
      schrieb am zuletzt editiert von OliverIO
      #2

      @great-sun

      Ein Scriptkontext oder auch Scope genannt, ist die aktuelle Sicht auf Variablen.
      Der Kontext kann je nach Funktionsaufruf sich auch ändern.
      Besonders bei Callback-Funktionen hat man hier immer wieder mal Schwierigkeiten
      Beispiel
      Du hast eine Funktion A innerhalb dessen Variablen benannt werden oder ein Objekt auf das du bspw mit this verweisen kannst.
      Innerhalb dieser Funktion rufst du eine andere Funktion (B) auf, an die du eine Callback Funktion (C) übergibst. Diese Funktion macht irgendetwas und wenn das Ziel erreicht ist, wird deine Callback Funktion (C) aufgerufen. Blöderweise kennt diese Callback-Funktion (C) zum Zeitpunkt des Aufrufs die darüberliegenden Variablen oder this nicht, weil sie in einem anderen Kontext (nämlich dieser Benutzerfunktion B) aufgerufen wurde. Um das zu beheben, musste man vor ES6 die bind-Funktion verwenden.

      Seit ES6 kann man dafür ein anderes Konstrukt verwenden, was es auch lesbarer macht

      Wenn du ein Link für die Doku hast, dann könnte man dir direkt helfen

      Beispiel

      ///Funktioniert nicht
      Function A() {
         var xxx="xxx";
         var yyy="yyy";
         B(yyy,function(zzz) {
            //mache irgendwas wenn Funktion B fertig ist
            //xxx ist hier nicht bekannt, da sie in einem anderen Scope definiert worden ist
         }
      }
      
      ///Funktioniert
      Function A() {
         var xxx="xxx";
         var yyy="yyy";
         B(yyy,function(xxx,zzz) {
            //mache irgendwas wenn Funktion B fertig ist
            //xxx ist hier bekannt, da sie an die Funktion gebunden wurde und als erster Parameter an den Callback übergeben wird.
         }.bind(xxx);
      }
      
      ///Neue Variante ab ES6 (iobroker node kann bereits seit langem es6
      //bitte achte auf die deklaration mit let und die andere Definitionsweise der Callbackfunktion, das nennt sich anonymous arrow function
      Function A() {
         let xxx="xxx";
         let yyy="yyy";
         B(yyy,(zzz) =>{
            //mache irgendwas wenn Funktion B fertig ist
            //xxx ist hier bekannt, da sie an die Funktion gebunden wurde und als erster Parameter an den Callback übergeben wird.
         };
      }
      
      

      Link bind
      Link Arrow Function
      Link Let

      Meine Adapter und Widgets
      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
      Links im Profil

      1 Antwort Letzte Antwort
      0
      • Great SUNG Offline
        Great SUNG Offline
        Great SUN
        schrieb am zuletzt editiert von
        #3

        @oliverio Danke, das ist sicher für die meisten eine nette Erklärung, aber welchen Context muss ich an eine im Script befindliche Funktion binden, damit die ihren Context behält?

        OliverIOO 1 Antwort Letzte Antwort
        0
        • Great SUNG Great SUN

          @oliverio Danke, das ist sicher für die meisten eine nette Erklärung, aber welchen Context muss ich an eine im Script befindliche Funktion binden, damit die ihren Context behält?

          OliverIOO Offline
          OliverIOO Offline
          OliverIO
          schrieb am zuletzt editiert von
          #4

          @great-sun
          so wie ich geschrieben habe.
          entweder ein objekt oder variable, die du ausserhalb definiert hast
          oder bspw this.
          je nachdem was du benötigst um beim aufruf der callback-funktion weiterarbeiten zu können.
          das kann halt nicht pauschal beantwortet werden, da das von der funktion an sich abhängt.
          wenn du einen debugger verwenden würdest, dann würdest du sehen, in welcher Zeile, welche Scope/Kontexte verfügbar sind.

          Hast du den kein Code-Beispiel oder Doku, aus der du diese Informationen hast?
          So aus 2.Hand lässt sich das nicht sagen

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          Great SUNG 1 Antwort Letzte Antwort
          0
          • OliverIOO OliverIO

            @great-sun
            so wie ich geschrieben habe.
            entweder ein objekt oder variable, die du ausserhalb definiert hast
            oder bspw this.
            je nachdem was du benötigst um beim aufruf der callback-funktion weiterarbeiten zu können.
            das kann halt nicht pauschal beantwortet werden, da das von der funktion an sich abhängt.
            wenn du einen debugger verwenden würdest, dann würdest du sehen, in welcher Zeile, welche Scope/Kontexte verfügbar sind.

            Hast du den kein Code-Beispiel oder Doku, aus der du diese Informationen hast?
            So aus 2.Hand lässt sich das nicht sagen

            Great SUNG Offline
            Great SUNG Offline
            Great SUN
            schrieb am zuletzt editiert von Great SUN
            #5

            @oliverio

            function getObjectValue(objectPath) {
                return getState(objectPath).val;
            }
            const autoConfigClass = new AutoConfigClass(getObjectValue.bind(this));
            

            Da weder this noch global oder globalThis hier zu funktionieren scheinen, kommt halt immer wieder:

            TypeError: this.getObjects is not a function
            
            OliverIOO 2 Antworten Letzte Antwort
            0
            • Great SUNG Great SUN

              @oliverio

              function getObjectValue(objectPath) {
                  return getState(objectPath).val;
              }
              const autoConfigClass = new AutoConfigClass(getObjectValue.bind(this));
              

              Da weder this noch global oder globalThis hier zu funktionieren scheinen, kommt halt immer wieder:

              TypeError: this.getObjects is not a function
              
              OliverIOO Offline
              OliverIOO Offline
              OliverIO
              schrieb am zuletzt editiert von
              #6

              @great-sun sagte in Was ist der Scriptcontext?:

              AutoConfigClass

              die doku zu AutoConfigClass

              Meine Adapter und Widgets
              TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
              Links im Profil

              Great SUNG 1 Antwort Letzte Antwort
              0
              • OliverIOO OliverIO

                @great-sun sagte in Was ist der Scriptcontext?:

                AutoConfigClass

                die doku zu AutoConfigClass

                Great SUNG Offline
                Great SUNG Offline
                Great SUN
                schrieb am zuletzt editiert von
                #7

                @oliverio Das ist was selbstgeschriebenes.

                OliverIOO 1 Antwort Letzte Antwort
                0
                • Great SUNG Great SUN

                  @oliverio

                  function getObjectValue(objectPath) {
                      return getState(objectPath).val;
                  }
                  const autoConfigClass = new AutoConfigClass(getObjectValue.bind(this));
                  

                  Da weder this noch global oder globalThis hier zu funktionieren scheinen, kommt halt immer wieder:

                  TypeError: this.getObjects is not a function
                  
                  OliverIOO Offline
                  OliverIOO Offline
                  OliverIO
                  schrieb am zuletzt editiert von
                  #8

                  @great-sun sagte in Was ist der Scriptcontext?:

                  this.getObjects

                  dies erscheint leider in deinem Beispielcode nirgends

                  Meine Adapter und Widgets
                  TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                  Links im Profil

                  1 Antwort Letzte Antwort
                  0
                  • Great SUNG Great SUN

                    @oliverio Das ist was selbstgeschriebenes.

                    OliverIOO Offline
                    OliverIOO Offline
                    OliverIO
                    schrieb am zuletzt editiert von OliverIO
                    #9

                    @great-sun sagte in Was ist der Scriptcontext?:

                    Das ist was selbstgeschriebenes

                    von dir? dann müsstest doch wissen was da übergeben wird.
                    Wenn von jemand anderem, dann den code hier posten oder denjenigen Fragen

                    Meine Adapter und Widgets
                    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                    Links im Profil

                    Great SUNG 1 Antwort Letzte Antwort
                    0
                    • OliverIOO OliverIO

                      @great-sun sagte in Was ist der Scriptcontext?:

                      Das ist was selbstgeschriebenes

                      von dir? dann müsstest doch wissen was da übergeben wird.
                      Wenn von jemand anderem, dann den code hier posten oder denjenigen Fragen

                      Great SUNG Offline
                      Great SUNG Offline
                      Great SUN
                      schrieb am zuletzt editiert von Great SUN
                      #10

                      @oliverio

                      Ich hab ein Script das ganz normal unter Scripte im ioBroker läuft. In dem ist die Funktion

                      function getObjectValue(objectPath) {
                          return getState(objectPath).val;
                      }
                      

                      Und von dort aus initialisiere ich die Klasse, der ich die lokale Funktion als Callback übergeben will,
                      Das funktionier ausserhalb mit zwei Klassen Problemlos, aber in ioBroker finde ich scheinbar einfach nicht den richtigen binding context.

                      in der Klasse ist das einfach so:

                      constructor(getObjects) {
                          this.getObjects = getObjects;
                      }
                      

                      Später wird dann halt irgendwo die Methode this.getObjects mit dem entsprechenden Pfad aufgerufen.
                      Wenn ich bei der Instanziierung also den richtigen Binding-Context übergebe, sollte das rein in meiner Theorie funktionieren.

                      Siehst Du das irgendwie anders?

                      Ein Beispiel mit zwei Klassen, das funktioniert:
                      PlayCode Beispiel

                      OliverIOO 1 Antwort Letzte Antwort
                      0
                      • Great SUNG Great SUN

                        @oliverio

                        Ich hab ein Script das ganz normal unter Scripte im ioBroker läuft. In dem ist die Funktion

                        function getObjectValue(objectPath) {
                            return getState(objectPath).val;
                        }
                        

                        Und von dort aus initialisiere ich die Klasse, der ich die lokale Funktion als Callback übergeben will,
                        Das funktionier ausserhalb mit zwei Klassen Problemlos, aber in ioBroker finde ich scheinbar einfach nicht den richtigen binding context.

                        in der Klasse ist das einfach so:

                        constructor(getObjects) {
                            this.getObjects = getObjects;
                        }
                        

                        Später wird dann halt irgendwo die Methode this.getObjects mit dem entsprechenden Pfad aufgerufen.
                        Wenn ich bei der Instanziierung also den richtigen Binding-Context übergebe, sollte das rein in meiner Theorie funktionieren.

                        Siehst Du das irgendwie anders?

                        Ein Beispiel mit zwei Klassen, das funktioniert:
                        PlayCode Beispiel

                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        schrieb am zuletzt editiert von OliverIO
                        #11

                        @great-sun

                        und woher hast du, das du da einen Kontext übergeben musst?
                        Aktuell musst du da gar nichts übergeben, da getState ja auch innerhalb des Objekts AutoConfigClass funktioniert, da es generell vom iobroker als Befehl bereitgestellt wird.
                        Alternativ übergebe nur den ObjectPath an das Objekt

                        Auch wenn ich dir das nicht rate, weil das viel zu kompliziert und nicht mehr lesbar wäre, kann man einen funktionsaufruf inklusive der Parameter einfrieren und zur späteren Ausführung aufheben.

                        Das wäre dann
                        apply
                        Aber das habe ich noch nie verwendet.

                        übertragen auf dein erstes Beispiel müsste es dann so aussehen

                        const autoConfigClass = new AutoConfigClass(getObjectValue.apply(null,"javascript.0.test1"));
                        

                        Der Inhalt des Parameters muss dann aber bekannt sein, sonst macht das keinen Sinn.

                        Meine Adapter und Widgets
                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                        Links im Profil

                        1 Antwort Letzte Antwort
                        0
                        • Great SUNG Offline
                          Great SUNG Offline
                          Great SUN
                          schrieb am zuletzt editiert von
                          #12

                          Na toll....
                          Das Problem war... Er hat mir beim Aufruf einer globalen Funktion noch eine andere Instanziierung gemacht, an die ich gar nicht mehr gedacht hatte. Im Log stand dann halt nur das Script, das ich ausgeführt hab, weswegen ich immer wieder dachte, das hängt an dem Script....

                          Danke trotzdem fürs Engagement und die beständige Hilfe/Suche nach dem Fehler.

                          Pebcak :-(

                          OliverIOO 1 Antwort Letzte Antwort
                          0
                          • Great SUNG Great SUN

                            Na toll....
                            Das Problem war... Er hat mir beim Aufruf einer globalen Funktion noch eine andere Instanziierung gemacht, an die ich gar nicht mehr gedacht hatte. Im Log stand dann halt nur das Script, das ich ausgeführt hab, weswegen ich immer wieder dachte, das hängt an dem Script....

                            Danke trotzdem fürs Engagement und die beständige Hilfe/Suche nach dem Fehler.

                            Pebcak :-(

                            OliverIOO Offline
                            OliverIOO Offline
                            OliverIO
                            schrieb am zuletzt editiert von
                            #13

                            @great-sun

                            noch ne anmerkung zu deinem playground

                            alle required anweisungen an den anfang stellen.
                            insbesondere willst du das nicht immer wieder neu ausführen (handeData)

                            sich innerhalb einer instanziierung eines objektes nicht veränderlichen daten, sollten auch nicht immer wieder neu berechnet werden handleData,Berechnung filePath

                            Wiederholter Dateizugriff auf die gleiche Ressource innerhalb kürzester Zeit gilt als inperformant. Daher sollten die Daten im Speicher gesammelt werden und dann nur einmal geschrieben werden. In der Schleife wird saveHash innerhalb weniger Millisekunden mehfach aufgerufen.

                            Die Übergabe des Callbacks müsste eigentlich auch ganz simple funktionieren
                            const testClass = new TestClass(dataClass.handleData);
                            in TestClass wird der Functionpointer dann gespeichert und später dann in setData zusammen mit den Parametern aufgerufen.

                            Meine Adapter und Widgets
                            TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                            Links im Profil

                            Great SUNG 1 Antwort Letzte Antwort
                            0
                            • OliverIOO OliverIO

                              @great-sun

                              noch ne anmerkung zu deinem playground

                              alle required anweisungen an den anfang stellen.
                              insbesondere willst du das nicht immer wieder neu ausführen (handeData)

                              sich innerhalb einer instanziierung eines objektes nicht veränderlichen daten, sollten auch nicht immer wieder neu berechnet werden handleData,Berechnung filePath

                              Wiederholter Dateizugriff auf die gleiche Ressource innerhalb kürzester Zeit gilt als inperformant. Daher sollten die Daten im Speicher gesammelt werden und dann nur einmal geschrieben werden. In der Schleife wird saveHash innerhalb weniger Millisekunden mehfach aufgerufen.

                              Die Übergabe des Callbacks müsste eigentlich auch ganz simple funktionieren
                              const testClass = new TestClass(dataClass.handleData);
                              in TestClass wird der Functionpointer dann gespeichert und später dann in setData zusammen mit den Parametern aufgerufen.

                              Great SUNG Offline
                              Great SUNG Offline
                              Great SUN
                              schrieb am zuletzt editiert von
                              #14

                              Generell bin ich voll bei Dir, das war nur zur Vereinfachung, dass jeder weiß, was gemeint/genutzt wird im playground.

                              Die Übergabe des Callbacks müsste eigentlich auch ganz simple funktionieren
                              const testClass = new TestClass(dataClass.handleData);
                              in TestClass wird der Functionpointer dann gespeichert und später dann in setData zusammen mit den Parametern aufgerufen.

                              Das geht nur mit .bind(dataClass) sonst heißt es is not a function ;-)

                              1 Antwort Letzte Antwort
                              0
                              Antworten
                              • In einem neuen Thema antworten
                              Anmelden zum Antworten
                              • Älteste zuerst
                              • Neuste zuerst
                              • Meiste Stimmen


                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              696

                              Online

                              32.6k

                              Benutzer

                              82.3k

                              Themen

                              1.3m

                              Beiträge
                              Community
                              Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                              ioBroker Community 2014-2025
                              logo
                              • Anmelden

                              • Du hast noch kein Konto? Registrieren

                              • Anmelden oder registrieren, um zu suchen
                              • Erster Beitrag
                                Letzter Beitrag
                              0
                              • Home
                              • Aktuell
                              • Tags
                              • Ungelesen 0
                              • Kategorien
                              • Unreplied
                              • Beliebt
                              • GitHub
                              • Docu
                              • Hilfe