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] Elegantere Programmierung?

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

[gelöst] Elegantere Programmierung?

Scheduled Pinned Locked Moved JavaScript
325 Posts 10 Posters 68.5k Views 8 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.
  • paul53P paul53

    @skorpil
    Du speicherst zwar die Sollwerte in den Merker-Datenpunkten, liest sie aber nur bei Skriptstart aus - anschließend nicht mehr.
    EDIT: Besser so:

    // ###########################################
    //      Lueften Terassentuer Werte merken
    //              und schreiben
    //              Deklarationen
    // ###########################################
    
    const IDthermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
    const IDthermWohnzi = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
    const IDthermEsszi  = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
     
    const IDthempKuecheMerk = 'javascript.0.BenutzerVariablen.TempMerkerKueche'/*TempKueche*/;
    const IDthempWohnziMerk = 'javascript.0.BenutzerVariablen.TempMerkerWohnzi'/*TempWohnzi*/;
    const IDthempEssziMerk  = 'javascript.0.BenutzerVariablen.TempMerkerEsszi'/*TempEsszi*/;
    
    const IDterTuerZustand  = 'javascript.0.BenutzerVariablen.TerrTuerLueften'/*TerTuer*/;
    
    // Datenpunkte erstellen;
    createState(IDthempKuecheMerk, 6, {
        name: 'TempKueche',
        type: 'number'
    });
     
    createState(IDthempWohnziMerk, 6, {
        name: 'TempWohnzi',
        type: 'number'
    });
     
    createState(IDthempEssziMerk, 6, {
        name: 'TempEsszi',
        type: 'number'
    });
     
    // ###########################################
    //            Programm
    // ###########################################
     
    on(IDterTuerZustand, function (dp) {
        if(!dp.state.val) { // Terassentuer ist "false = geschlossen", dann setze die vorher
            // gespeicherten Themperaturen und schalte es auf AUTO
            // Variable zur Einstellung des Termostats
            var modus = 1; // 1 = AUTO; 2 = CEN
     
            setState(IDthermKueche, getState(IDthempKuecheMerk).val);
            setState(IDthermEsszi,  getState(IDthempEssziMerk).val);
            setState(IDthermWohnzi, getState(IDthempWohnziMerk).val);
            setTimeout(function() {
                thermometerSetzen(IDthermKueche, modus);
                thermometerSetzen(IDthermEsszi, modus);
                thermometerSetzen(IDthermWohnzi, modus);
            }, 500);
        } else { // Terassentuer ist "true = offen", dann merke die 
            // momentanen Temperaturen und schalte die Thermostate auf CEN und aus
            // Variable zur Einstellung des Termostats
            modus = 2; // 1 = AUTO; 2 = CEN
     
            // schreibe die momentane Temperaturen in die Merker, setze auf CEN und 0
                
            setState(IDthempKuecheMerk, getState(IDthermKueche).val);
            setState(IDthempEssziMerk, getState(IDthermEsszi).val);
            setState(IDthempWohnziMerk, getState(IDthermWohnzi).val);
            thermometerSetzen(IDthermKueche, modus);
            thermometerSetzen(IDthermEsszi, modus);
            thermometerSetzen(IDthermWohnzi, modus);
            setTimeout(function() {
                setState(IDthermKueche, 6);
                setState(IDthermEsszi, 6);
                setState(IDthermWohnzi, 6);
            }, 500);
        }
    });
    
    S Offline
    S Offline
    skorpil
    wrote on last edited by
    #312

    @paul53 ich wußte nicht, dass man createState auch so verwenden kann:

    createState(IDthempEssziMerk, 6, {
        name: 'ThempEsszi',
        type: 'number'
    });
    

    Danke.

    Verwendung von if else und das Auslesen der Merker Datenpunkte: ich bin begeistert.

    Klasse u., vielen Dank. Ich teste morgen

    S 1 Reply Last reply
    0
    • S skorpil

      @paul53 ich wußte nicht, dass man createState auch so verwenden kann:

      createState(IDthempEssziMerk, 6, {
          name: 'ThempEsszi',
          type: 'number'
      });
      

      Danke.

      Verwendung von if else und das Auslesen der Merker Datenpunkte: ich bin begeistert.

      Klasse u., vielen Dank. Ich teste morgen

      S Offline
      S Offline
      skorpil
      wrote on last edited by
      #313

      @paul53 Test erfolgreich! Alles richtig. Nochmals: Danke!

      1 Reply Last reply
      0
      • Karel PuhliK Online
        Karel PuhliK Online
        Karel Puhli
        wrote on last edited by
        #314

        Alleine diese 313 Posts zu lesen ist doch schon fast ein eigenes JS Tutorial! :-)
        Echt toll, wie hier geholfen wird!!!

        S 1 Reply Last reply
        1
        • Karel PuhliK Online
          Karel PuhliK Online
          Karel Puhli
          wrote on last edited by
          #315
          const fensterArray = [
              "0_userdata.0.Fenster1",
              "0_userdata.0.Fenster2",
              "0_userdata.0.Fenster3"
          ];
          
          
          
          on(fensterArray, async (data) => {
              var fensterString = [`Aktuell ist`];
              for (var i = 0; i < fensterArray.length; i++) {
                  if (getState(fensterArray[i]).val) {
                      fensterString.push((fensterArray[i]));
                      fensterString.push(`offen!`);
                  }
                  
              }
              if (fensterString.length == 1) {
                  fensterString.push(`alles geschlossen!`);
              }
              console.log(fensterString.join(" "));
          });
          

          Ich würde gerne aus dem Array "fensterArray" nur den Namen in das Array "fensterString" pushen. In meinem Skript wird die komplette ID gepusht. Jemand ne Lösung?

          Danke :-)

          paul53P 1 Reply Last reply
          0
          • Karel PuhliK Karel Puhli
            const fensterArray = [
                "0_userdata.0.Fenster1",
                "0_userdata.0.Fenster2",
                "0_userdata.0.Fenster3"
            ];
            
            
            
            on(fensterArray, async (data) => {
                var fensterString = [`Aktuell ist`];
                for (var i = 0; i < fensterArray.length; i++) {
                    if (getState(fensterArray[i]).val) {
                        fensterString.push((fensterArray[i]));
                        fensterString.push(`offen!`);
                    }
                    
                }
                if (fensterString.length == 1) {
                    fensterString.push(`alles geschlossen!`);
                }
                console.log(fensterString.join(" "));
            });
            

            Ich würde gerne aus dem Array "fensterArray" nur den Namen in das Array "fensterString" pushen. In meinem Skript wird die komplette ID gepusht. Jemand ne Lösung?

            Danke :-)

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

            @karel-puhli sagte: nur den Namen in das Array "fensterString" pushen.

                        fensterString.push(getObject(fensterArray[i]).common.name);
            

            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

            Karel PuhliK 1 Reply Last reply
            1
            • paul53P paul53

              @karel-puhli sagte: nur den Namen in das Array "fensterString" pushen.

                          fensterString.push(getObject(fensterArray[i]).common.name);
              
              Karel PuhliK Online
              Karel PuhliK Online
              Karel Puhli
              wrote on last edited by
              #317

              @paul53 sagte in [gelöst] Elegantere Programmierung?:

              fensterString.push(getObject(fensterArray[i]).common.name);

              getObject() :+1:

              Danke Paul!!!!

              1 Reply Last reply
              1
              • Karel PuhliK Karel Puhli

                Alleine diese 313 Posts zu lesen ist doch schon fast ein eigenes JS Tutorial! :-)
                Echt toll, wie hier geholfen wird!!!

                S Offline
                S Offline
                skorpil
                wrote on last edited by skorpil
                #318

                @karel-puhli das stimmt! Ich bin auch den Kollegen wahnsinnig dankbar! Und besonders hervorzuheben @paul53

                Karel PuhliK 1 Reply Last reply
                0
                • S skorpil

                  @karel-puhli das stimmt! Ich bin auch den Kollegen wahnsinnig dankbar! Und besonders hervorzuheben @paul53

                  Karel PuhliK Online
                  Karel PuhliK Online
                  Karel Puhli
                  wrote on last edited by
                  #319

                  @skorpil

                  Dat stimmt! Mit Profis arbeiten ist immer von Vorteil! ;-)

                  S 1 Reply Last reply
                  0
                  • Karel PuhliK Karel Puhli

                    @skorpil

                    Dat stimmt! Mit Profis arbeiten ist immer von Vorteil! ;-)

                    S Offline
                    S Offline
                    skorpil
                    wrote on last edited by
                    #320

                    @karel-puhli ich habe ein Helferlein gefunden, welche man auch ganz gut für Basic Fragen nutzen kann

                    https://forum.iobroker.net/topic/65392/chatgbt-für-javascript-text-in-mp3-ausgabe-auf-alexa?_=1684002283643

                    Es arbeitet zwar noch sehr, sehr basic und hat bei meiner Anfrage KEIN verwertbares Ergebnis geliefert.

                    Aber eine Fehler im Script bei einer andere. Anfrage hat er schon gefunden. Denn man will ja den Kollegen hier auch nicht zu oft auf den Wecker gehen.

                    1 Reply Last reply
                    0
                    • S Offline
                      S Offline
                      skorpil
                      wrote on last edited by
                      #321

                      @paul53 ich habe eine Logik Frage. Wann triggert diese On Anweisung:

                      on([urlaub, sommer], change : any, function () {
                      

                      Und wann diese?

                      on([urlaub, sommer], function () {
                      

                      Oder anders gefragt: würde die letzte On Anweisung triggern, wenn beide den Wert 0 haben.

                      Mein Ziel ist, dass bei JEDER Änderung der Variablen "sommer" und "urlaub" das Script ausgeführt wird. Denn die verschiedenen Fälleprüfe ich anschließend mit einer IF Anweisung der Form:

                      if(getState(urlaub).val == 0 && getState(sommer).val == 0) {
                      // oder
                      if(getState(urlaub).val == 0 && getState(sommer).val == 1) {
                      // oder
                      if(getState(urlaub).val == 1 && getState(sommer).val == 0) {
                      // oder
                      if(getState(urlaub).val == 1 && getState(sommer).val == 1) {
                      
                      paul53P 1 Reply Last reply
                      0
                      • S skorpil

                        @paul53 ich habe eine Logik Frage. Wann triggert diese On Anweisung:

                        on([urlaub, sommer], change : any, function () {
                        

                        Und wann diese?

                        on([urlaub, sommer], function () {
                        

                        Oder anders gefragt: würde die letzte On Anweisung triggern, wenn beide den Wert 0 haben.

                        Mein Ziel ist, dass bei JEDER Änderung der Variablen "sommer" und "urlaub" das Script ausgeführt wird. Denn die verschiedenen Fälleprüfe ich anschließend mit einer IF Anweisung der Form:

                        if(getState(urlaub).val == 0 && getState(sommer).val == 0) {
                        // oder
                        if(getState(urlaub).val == 0 && getState(sommer).val == 1) {
                        // oder
                        if(getState(urlaub).val == 1 && getState(sommer).val == 0) {
                        // oder
                        if(getState(urlaub).val == 1 && getState(sommer).val == 1) {
                        
                        paul53P Offline
                        paul53P Offline
                        paul53
                        wrote on last edited by
                        #322

                        @skorpil sagte: Wann triggert diese On Anweisung:

                        Diese Anweisung ist falsch. Richtig:

                        on({id: [urlaub, sommer], change: any}, function () {
                        

                        Sie triggert bei jeder Aktualisierung des Zeitstempels eines der Datenpunkte, auch dann, wenn sich der Wert nicht ändert. Sie ist identisch mit dieser Anweisung:

                        on({id: [urlaub, sommer]}, function () {
                        

                        @skorpil sagte in [gelöst] Elegantere Programmierung?:

                        Und wann diese?

                        Diese Anweisung triggert bei Wertänderung eines der beiden Datenpunkte.

                        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

                        S 1 Reply Last reply
                        1
                        • paul53P paul53

                          @skorpil sagte: Wann triggert diese On Anweisung:

                          Diese Anweisung ist falsch. Richtig:

                          on({id: [urlaub, sommer], change: any}, function () {
                          

                          Sie triggert bei jeder Aktualisierung des Zeitstempels eines der Datenpunkte, auch dann, wenn sich der Wert nicht ändert. Sie ist identisch mit dieser Anweisung:

                          on({id: [urlaub, sommer]}, function () {
                          

                          @skorpil sagte in [gelöst] Elegantere Programmierung?:

                          Und wann diese?

                          Diese Anweisung triggert bei Wertänderung eines der beiden Datenpunkte.

                          S Offline
                          S Offline
                          skorpil
                          wrote on last edited by skorpil
                          #323

                          @paul53 Sorry, Deine Antwort sieht bei mir so aus:

                          IMG_4745.jpeg

                          Das ist irgendwie missverständlich. „Diese Anweisung ist falsch“ Welche?

                          Ich will nicht, dass bei jeder Änderung des ZEITSTEMPEL das Script ausgeführt wird. Das wäre hier ja Quatsch. Also ist

                          on([urlaub, sommer], function () {
                          

                          richtig? Bei WertÄNDERUNG? Oder muss „id:“ noch dazu. Das war ja bei mir nicht der Fall. Bin verwirrt!

                          Karel PuhliK 1 Reply Last reply
                          0
                          • S skorpil

                            @paul53 Sorry, Deine Antwort sieht bei mir so aus:

                            IMG_4745.jpeg

                            Das ist irgendwie missverständlich. „Diese Anweisung ist falsch“ Welche?

                            Ich will nicht, dass bei jeder Änderung des ZEITSTEMPEL das Script ausgeführt wird. Das wäre hier ja Quatsch. Also ist

                            on([urlaub, sommer], function () {
                            

                            richtig? Bei WertÄNDERUNG? Oder muss „id:“ noch dazu. Das war ja bei mir nicht der Fall. Bin verwirrt!

                            Karel PuhliK Online
                            Karel PuhliK Online
                            Karel Puhli
                            wrote on last edited by Karel Puhli
                            #324

                            @skorpil sagte in [gelöst] Elegantere Programmierung?:

                            Also ist
                            on([urlaub, sommer], function () {

                            richtig?

                            Richtig!!! Da muss kein id: dazu. Hier hast du einen String / ein Array mit Strings. Diese on fkt triggert nur auf Änderung!

                            Wenn du anstatt des Strings, ein Object in die on fkt packst, muss id: dazu. In diesem Object kannst du weitere Parameter wie val: oder ack: oder change: dazu nehmen und die Fkt schärfer auf einen bestimmten Anwendungsfall zuschneiden.

                            on([dp1, "0_userdata.0.ButtonTest"], async (data) => {
                            

                            hier ein Bsp. als Array mit Strings (egal ob Variable oder der String direkt).

                            on({id: id1, val: true, change: "ne"}, async function(data) {
                            

                            Und hier ein Bsp mit Objekt.

                            btw: das eine ist eine Pfeilfuntkion (=>), das andere die "normale" Schreibweise. Macht aber das selbe.

                            S 1 Reply Last reply
                            1
                            • Karel PuhliK Karel Puhli

                              @skorpil sagte in [gelöst] Elegantere Programmierung?:

                              Also ist
                              on([urlaub, sommer], function () {

                              richtig?

                              Richtig!!! Da muss kein id: dazu. Hier hast du einen String / ein Array mit Strings. Diese on fkt triggert nur auf Änderung!

                              Wenn du anstatt des Strings, ein Object in die on fkt packst, muss id: dazu. In diesem Object kannst du weitere Parameter wie val: oder ack: oder change: dazu nehmen und die Fkt schärfer auf einen bestimmten Anwendungsfall zuschneiden.

                              on([dp1, "0_userdata.0.ButtonTest"], async (data) => {
                              

                              hier ein Bsp. als Array mit Strings (egal ob Variable oder der String direkt).

                              on({id: id1, val: true, change: "ne"}, async function(data) {
                              

                              Und hier ein Bsp mit Objekt.

                              btw: das eine ist eine Pfeilfuntkion (=>), das andere die "normale" Schreibweise. Macht aber das selbe.

                              S Offline
                              S Offline
                              skorpil
                              wrote on last edited by
                              #325

                              @karel-puhli merci für die Aufklärung

                              1 Reply Last reply
                              0
                              Reply
                              • Reply as topic
                              Log in to reply
                              • Oldest to Newest
                              • Newest to Oldest
                              • Most Votes


                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              630

                              Online

                              32.7k

                              Users

                              82.4k

                              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