Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. Auslesen von Objektstruktur über Javascript

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Auslesen von Objektstruktur über Javascript

    This topic has been deleted. Only users with topic management privileges can see it.
    • G
      gammler2003 last edited by

      Hallo zusammen,

      ich würde gerne die Namen der Ordner in der Struktur meiner Objekte in ioBroker über Javascript auslesen.

      Bildschirmfoto 2020-05-04 um 17.16.35.png

      Ganz konkret möchte ich die Namen aller Ordner (u.a. den schwarz markierten) auslesen, die unter dem übergeordneten Ordner "devices" hängen. Also nicht die Werte von einzelnen Datenpunkten, sondern tatsächlich die Namen der übergeordneten Ordner.

      Hat jemand eine Idee, wie/ob das funktionieren kann?

      Vielen Dank an euch vorab.

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

        @gammler2003 sagte:

        die Namen der übergeordneten Ordner.

        Eine Möglichkeit:

        id = id.split('.'); // Datenpunkt-ID
        log(id[id.length - 2]);
        
        1 Reply Last reply Reply Quote 0
        • G
          gammler2003 last edited by

          @paul53 said in Auslesen von Objektstruktur über Javascript:

          id = id.split('.'); // Datenpunkt-ID
          log(id[id.length - 2]);

          Hallo & vielen Dank für die schnelle Rückmeldung.
          Leider hilft mir das nur bedingt. Mein Ausgangspunkt soll der Ordner "tr-064.0.devices" sein.

          Die konkrete Anforderung => Gebe mir die Namen aller Ordner, die unter "tr-064.0.devices" liegen.

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

            @gammler2003 sagte:

            Namen aller Ordner, die unter "tr-064.0.devices" liegen

            var devices = [];
            $('tr-064.0.devices.*').each(function(id, i) {
                let dev = id.split('.')[3];
                if(devices.indexOf(dev) == -1) devices.push(dev);
            });
            // Array devices enthält jedes Device einmal
            
            1 Reply Last reply Reply Quote 0
            • G
              gammler2003 last edited by

              Genau das habe ich gesucht - herzlichen Dank!

              1 Reply Last reply Reply Quote 0
              • G
                gammler2003 last edited by

                Jetzt hat sich doch noch einmal eine Frage ergeben, auf die ich leider bisher keine passende Antwort gefunden habe.

                Besteht die Möglichkeit, dass ich einen Trigger auf den Knoten "devices" setze? Dieser soll immer dann anspringen, wenn in irgendeinem beliebigen Datenpunkt in der Struktur unter "devices" eine Änderung stattgefunden hat.

                Vielen Dank nochmals für euren Support!

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

                  @gammler2003 sagte:

                  Besteht die Möglichkeit, dass ich einen Trigger auf den Knoten "devices" setze?

                  Ja, $Selector.on()

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

                    @paul53 said in Auslesen von Objektstruktur über Javascript:

                    $Selector.on()

                    Vielen Dank - liefert mir aber, so wie ich es jetzt eingebaut habe, einen Fehler. Meine erste Zeile sieht wie folgt aus:

                    $Selector.on({id: 'tr-064.0.devices.*', change: "ne"}, function (obj) {
                    
                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @gammler2003 last edited by paul53

                      @gammler2003 sagte:

                      Meine erste Zeile sieht wie folgt aus:

                      const ids = $('tr-064.0.devices.*'); // das ist der Selector
                      var devices = [];
                      
                      ids.on(function() { // triggert bei Wertänderung aller Datenpunkte des Selectors
                          ids.each(function(id, i) {
                              let dev = id.split('.')[3];
                              if(devices.indexOf(dev) == -1) devices.push(dev);
                          });
                          // Array devices enthält jedes Device einmal
                      });
                      
                      1 Reply Last reply Reply Quote 0
                      • G
                        gammler2003 last edited by

                        Super, danke! Trigger funktioniert und Array schreiben auch.
                        Jetzt will ich mit dem Array weiterarbeiten - genauer gesagt will ich in einem zweiten Array die Zustände der Geräte abfragen (true/false) und davon abhängig einen weiteren Datenpunkt setzen.

                        Jedoch habe ich das Problem, dass der Trigger

                        ids.on(function() { // triggert bei Wertänderung aller Datenpunkte des Selectors
                            ids.each(function(id, i) {
                                let dev = id.split('.')[3];
                                if(devices.indexOf(dev) == -1) devices.push(dev);
                            });
                            // Array devices enthält jedes Device einmal
                        });
                        
                        

                        nicht nur einmal triggert bei Wertänderung, sondern die Anzahl der Datenpunkte (in meinem Fall 4x).

                        Kurz gesagt: Wenn sich einer der Datenpunkte des Selektors ändert, soll einmalig getriggert werden.

                        Gibt es soetwas?

                        Vielen Dank.

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

                          @gammler2003 sagte:

                          Problem, dass der Tigger nicht nur einmal triggert bei Wertänderung, sondern die Anzahl der Datenpunkte

                          ?? Der Trigger reagiert jedesmal, wenn sich der Wert eines der Datenpunkte des Selectors ändert. In der each-Schleife werden dann alle Datenpunkte abgeklappert.
                          Was möchtest Du erreichen ?

                          @gammler2003 sagte in Auslesen von Objektstruktur über Javascript:

                          Zustände der Geräte abfragen (true/false)

                          Nur Datenpunkte haben Zustände.

                          1 Reply Last reply Reply Quote 0
                          • G
                            gammler2003 last edited by

                            Ich möchte alle Datenpunkte unter einem Knoten überwachen. Sobald sich der Wert von einem dieser Datenpunkte ändert, soll eine Aktion (z.B. Konsolenausgabe) getriggert werden.

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

                              @gammler2003 sagte:

                              Sobald sich der Wert von einem dieser Datenpunkte ändert

                              Genau dann wird getriggert: Wenn sich Wert eines der im Selector erfassen Datenpunkte ändert . Wie möchtest Du es auswerten ? Was soll in der Ausgabe erscheinen ?

                              const ids = $('tr-064.0.devices.*'); // das ist der Selector
                              // var devices = [];
                               
                              ids.on(function(dp) { // triggert bei Wertänderung eines der Datenpunkte des Selectors
                                  log('Änderung von: ' + dp.common.name + ', neuer Wert: ' + dp.state.val);
                              /*    ids.each(function(id, i) {
                                      let dev = id.split('.')[3];
                                      if(devices.indexOf(dev) == -1) devices.push(dev);
                                  });
                              */    // Array devices enthält jedes Device einmal
                              });
                              
                              1 Reply Last reply Reply Quote 0
                              • First post
                                Last post

                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              212
                              Online

                              31.7k
                              Users

                              79.8k
                              Topics

                              1.3m
                              Posts

                              javaskript
                              2
                              13
                              1252
                              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