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

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.7k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.1k

[gelöst] Elegantere Programmierung?

Geplant Angeheftet Gesperrt Verschoben JavaScript
325 Beiträge 10 Kommentatoren 64.9k Aufrufe 8 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.
  • paul53P paul53

    @skorpil sagte: Meinung?

    Du deklarierst z.B. thempKuecheMerk als Datenpunkt-ID - was die Fehlermeldungen erzeugt, aber dann soll sie den Wert des DP enthalten. Ändere Zeilen 27 bis 29 so, dass die Variablen bei Skriptstart den Sollwert enthalten, falls er > 0 ist. Sonst initialisiere sie mit einem typischen Wert.

    var thempKuecheMerk = getState(IDthermKueche).val;
    if (thempKuecheMerk < 10) thempKuecheMerk = 20;
    
    S Offline
    S Offline
    skorpil
    schrieb am zuletzt editiert von skorpil
    #310

    @paul53 ich hatte mir wieder selber die Karten gelegt...:angry: und Datenpunkt und Wert des Datenpunkts nicht sauber auseinander gehalten. Und zwar hier (usw.):

    const IDthempKuecheMerk = 'javascript.0.BenutzerVariablen.ThempMerkerKueche'/*ThempKueche*/;
    var thempKuecheMerk = getState(IDthempKuecheMerk).val;
    

    Jetzt ist das Script angepasst und sollte so funktionieren. Zumindest der Lifetest scheint geklappt zu haben. Schaust Du dennoch noch mal drüber bitte?

    // ###########################################
    //      Lueften Terassentuer Werte merken
    //              und schreiben
    //              Deklarationen
    // ###########################################
    
    // Datenpunkte erstellen;
    createState('BenutzerVariablen.ThempMerkerKueche', '', {
        name: 'ThempKueche',
        type: 'number'
    });
    
    createState('BenutzerVariablen.ThempMerkerWohnzi', '', {
        name: 'ThempWohnzi',
        type: 'number'
    });
    
    createState('BenutzerVariablen.ThempMerkerEsszi', '', {
        name: 'ThempEsszi',
        type: 'number'
    });
    
    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.ThempMerkerKueche'/*ThempKueche*/;
    const IDthempWohnziMerk = 'javascript.0.BenutzerVariablen.ThempMerkerWohnzi'/*ThempWohnzi*/;
    const IDthempEssziMerk = 'javascript.0.BenutzerVariablen.ThempMerkerEsszi'/*ThempEsszi*/;
    
    var thempKuecheMerk = getState(IDthempKuecheMerk).val;
    var thempWohnziMerk = getState(IDthempWohnziMerk).val;
    var thempEssziMerk = getState(IDthempEssziMerk).val;
    
    const terTuerZustand = 'javascript.0.BenutzerVariablen.TerrTuerLueften'/*TerTuer*/;
    
    
    // ###########################################
    //            Programm
    // ###########################################
    
    on(terTuerZustand, 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
    
                // schreibe die momentane Temperaturen in die Merker, setze auf CEN und 0
                thermometerSetzen(IDthermKueche, modus);
                setStateDelayed(IDthermKueche,thempKuecheMerk, 500);
    
                thermometerSetzen(IDthermEsszi, modus);
                setStateDelayed(IDthermEsszi,thempEssziMerk, 500);
    
                thermometerSetzen(IDthermWohnzi, modus);
                setStateDelayed(IDthermWohnzi,thempWohnziMerk, 500);
        };
    
        if(dp.state.val) { // Terassentuer ist "true = offen", dann merke die 
                           // momentanen Temperaturen und schalte die Thermostate auf CEN und aus
    
                // Variable zur Einstellung des Termostats
                var modus = 2; // 1 = AUTO; 2 = CEN
    
                // schreibe die momentane Temperaturen in die Merker, setze auf CEN und 0
                
                thermometerSetzen(IDthermKueche, modus);
                setState(IDthempKuecheMerk, getState(IDthermKueche).val);
                setStateDelayed(IDthermKueche, 6, 500);
    
                thermometerSetzen(IDthermEsszi, modus);
                setState(IDthempEssziMerk, getState(IDthermEsszi).val);
                setStateDelayed(IDthermEsszi, 6, 500);
    
                thermometerSetzen(IDthermWohnzi, modus);
                setState(IDthempWohnziMerk, getState(IDthermWohnzi).val);
                setStateDelayed(IDthermWohnzi, 6, 500);
        };
    });          
    
    paul53P 1 Antwort Letzte Antwort
    0
    • S skorpil

      @paul53 ich hatte mir wieder selber die Karten gelegt...:angry: und Datenpunkt und Wert des Datenpunkts nicht sauber auseinander gehalten. Und zwar hier (usw.):

      const IDthempKuecheMerk = 'javascript.0.BenutzerVariablen.ThempMerkerKueche'/*ThempKueche*/;
      var thempKuecheMerk = getState(IDthempKuecheMerk).val;
      

      Jetzt ist das Script angepasst und sollte so funktionieren. Zumindest der Lifetest scheint geklappt zu haben. Schaust Du dennoch noch mal drüber bitte?

      // ###########################################
      //      Lueften Terassentuer Werte merken
      //              und schreiben
      //              Deklarationen
      // ###########################################
      
      // Datenpunkte erstellen;
      createState('BenutzerVariablen.ThempMerkerKueche', '', {
          name: 'ThempKueche',
          type: 'number'
      });
      
      createState('BenutzerVariablen.ThempMerkerWohnzi', '', {
          name: 'ThempWohnzi',
          type: 'number'
      });
      
      createState('BenutzerVariablen.ThempMerkerEsszi', '', {
          name: 'ThempEsszi',
          type: 'number'
      });
      
      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.ThempMerkerKueche'/*ThempKueche*/;
      const IDthempWohnziMerk = 'javascript.0.BenutzerVariablen.ThempMerkerWohnzi'/*ThempWohnzi*/;
      const IDthempEssziMerk = 'javascript.0.BenutzerVariablen.ThempMerkerEsszi'/*ThempEsszi*/;
      
      var thempKuecheMerk = getState(IDthempKuecheMerk).val;
      var thempWohnziMerk = getState(IDthempWohnziMerk).val;
      var thempEssziMerk = getState(IDthempEssziMerk).val;
      
      const terTuerZustand = 'javascript.0.BenutzerVariablen.TerrTuerLueften'/*TerTuer*/;
      
      
      // ###########################################
      //            Programm
      // ###########################################
      
      on(terTuerZustand, 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
      
                  // schreibe die momentane Temperaturen in die Merker, setze auf CEN und 0
                  thermometerSetzen(IDthermKueche, modus);
                  setStateDelayed(IDthermKueche,thempKuecheMerk, 500);
      
                  thermometerSetzen(IDthermEsszi, modus);
                  setStateDelayed(IDthermEsszi,thempEssziMerk, 500);
      
                  thermometerSetzen(IDthermWohnzi, modus);
                  setStateDelayed(IDthermWohnzi,thempWohnziMerk, 500);
          };
      
          if(dp.state.val) { // Terassentuer ist "true = offen", dann merke die 
                             // momentanen Temperaturen und schalte die Thermostate auf CEN und aus
      
                  // Variable zur Einstellung des Termostats
                  var modus = 2; // 1 = AUTO; 2 = CEN
      
                  // schreibe die momentane Temperaturen in die Merker, setze auf CEN und 0
                  
                  thermometerSetzen(IDthermKueche, modus);
                  setState(IDthempKuecheMerk, getState(IDthermKueche).val);
                  setStateDelayed(IDthermKueche, 6, 500);
      
                  thermometerSetzen(IDthermEsszi, modus);
                  setState(IDthempEssziMerk, getState(IDthermEsszi).val);
                  setStateDelayed(IDthermEsszi, 6, 500);
      
                  thermometerSetzen(IDthermWohnzi, modus);
                  setState(IDthempWohnziMerk, getState(IDthermWohnzi).val);
                  setStateDelayed(IDthermWohnzi, 6, 500);
          };
      });          
      
      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von paul53
      #311

      @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);
          }
      });
      

      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 Antwort Letzte Antwort
      0
      • 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
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #313

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

          1 Antwort Letzte Antwort
          0
          • Karel PuhliK Offline
            Karel PuhliK Offline
            Karel Puhli
            schrieb am zuletzt editiert von
            #314

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

            S 1 Antwort Letzte Antwort
            1
            • Karel PuhliK Offline
              Karel PuhliK Offline
              Karel Puhli
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                1
                • paul53P paul53

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

                              fensterString.push(getObject(fensterArray[i]).common.name);
                  
                  Karel PuhliK Offline
                  Karel PuhliK Offline
                  Karel Puhli
                  schrieb am zuletzt editiert von
                  #317

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

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

                  getObject() :+1:

                  Danke Paul!!!!

                  1 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von skorpil
                    #318

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

                    Karel PuhliK 1 Antwort Letzte Antwort
                    0
                    • S skorpil

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

                      Karel PuhliK Offline
                      Karel PuhliK Offline
                      Karel Puhli
                      schrieb am zuletzt editiert von
                      #319

                      @skorpil

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

                      S 1 Antwort Letzte Antwort
                      0
                      • Karel PuhliK Karel Puhli

                        @skorpil

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

                        S Offline
                        S Offline
                        skorpil
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        0
                        • S Offline
                          S Offline
                          skorpil
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                              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 Offline
                                Karel PuhliK Offline
                                Karel Puhli
                                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #325

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

                                  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

                                  504

                                  Online

                                  32.4k

                                  Benutzer

                                  81.5k

                                  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