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. Script verbesserung

NEWS

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

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

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

Script verbesserung

Scheduled Pinned Locked Moved JavaScript
9 Posts 3 Posters 615 Views 2 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.
  • A Online
    A Online
    australien
    wrote on last edited by
    #1

    Hallo zusammen,

    ich fange gerade mit Javascript an und hätte da mal was zum Drüberschauen.

    Passt das so, oder wie kann man das Verbessern?

    danke für Eure Tipps

    /* 
    Wenn der Automower seine Unterkunft (Station) verlassen hat, darf die Bewässerung
    nicht anspringen.
    Bei der Bewässerung ist ein Shelly1 zwischen Steuerung und Pumpe eingebaut.
    Via MQTT wird das Relais (GrundwasserPumpe) geschaltet.
    
    Version:
        1.0 ist der Mäher zu hause, keine Bewässerung
        1.1 Bewässerung wird mit den letzten 24h Niederschlag aus Wetterstation vernetzt
    */
    
    const iDausloeser     = 'alias.0.Rasenflaeche.Station';
    const iDpumpe         = 'alias.0.Rasenflaeche.GrundwasserPumpe';
    var iDniederschlag24, iDniederschlag24_ts;
    
    iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
    iDniederschlag24_ts = getState('alias.0.Wetter.Doki.Niederschlag24h').ts;
    
     // triggert bei Mäher Aus- Einfahrt
    on({id: "alias.0.Rasenflaeche.Station", change: "any"}, function(dp) {
        iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
        if(iDniederschlag24 == 0){  /* Niederschlag die letzten 24h */
            if(getState(iDausloeser).val) {
                setState(iDpumpe, true);
            } else {
                setState(iDpumpe, false);
                }
        } else {
            setState(iDpumpe, false);
            }
        console.log('Niederschlag --- Mäher  --->>> ' + iDniederschlag24 + ' mm/24h');
    });
    
    // triggert ber Niederschlag die letzten 24h
    on({id: "alias.0.Wetter.Doki.Niederschlag24h", change: "any"}, function(dp) {
        iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
        
        console.log('Niederschlag  --- 24h  ---->>> ' + iDniederschlag24 + ' mm/24h');
        if(iDniederschlag24==0) {
                setState(iDpumpe, true);
                console.log('Niederschlag  --->  Pumpe an');
        } else {
                setState(iDpumpe, false); 
                console.log('Niederschlag  --->  Pumpe aus');
                } 
    });
    
    
    haus-automatisierungH paul53P 2 Replies Last reply
    0
    • A australien

      Hallo zusammen,

      ich fange gerade mit Javascript an und hätte da mal was zum Drüberschauen.

      Passt das so, oder wie kann man das Verbessern?

      danke für Eure Tipps

      /* 
      Wenn der Automower seine Unterkunft (Station) verlassen hat, darf die Bewässerung
      nicht anspringen.
      Bei der Bewässerung ist ein Shelly1 zwischen Steuerung und Pumpe eingebaut.
      Via MQTT wird das Relais (GrundwasserPumpe) geschaltet.
      
      Version:
          1.0 ist der Mäher zu hause, keine Bewässerung
          1.1 Bewässerung wird mit den letzten 24h Niederschlag aus Wetterstation vernetzt
      */
      
      const iDausloeser     = 'alias.0.Rasenflaeche.Station';
      const iDpumpe         = 'alias.0.Rasenflaeche.GrundwasserPumpe';
      var iDniederschlag24, iDniederschlag24_ts;
      
      iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
      iDniederschlag24_ts = getState('alias.0.Wetter.Doki.Niederschlag24h').ts;
      
       // triggert bei Mäher Aus- Einfahrt
      on({id: "alias.0.Rasenflaeche.Station", change: "any"}, function(dp) {
          iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
          if(iDniederschlag24 == 0){  /* Niederschlag die letzten 24h */
              if(getState(iDausloeser).val) {
                  setState(iDpumpe, true);
              } else {
                  setState(iDpumpe, false);
                  }
          } else {
              setState(iDpumpe, false);
              }
          console.log('Niederschlag --- Mäher  --->>> ' + iDniederschlag24 + ' mm/24h');
      });
      
      // triggert ber Niederschlag die letzten 24h
      on({id: "alias.0.Wetter.Doki.Niederschlag24h", change: "any"}, function(dp) {
          iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
          
          console.log('Niederschlag  --- 24h  ---->>> ' + iDniederschlag24 + ' mm/24h');
          if(iDniederschlag24==0) {
                  setState(iDpumpe, true);
                  console.log('Niederschlag  --->  Pumpe an');
          } else {
                  setState(iDpumpe, false); 
                  console.log('Niederschlag  --->  Pumpe aus');
                  } 
      });
      
      
      haus-automatisierungH Online
      haus-automatisierungH Online
      haus-automatisierung
      Developer Most Active
      wrote on last edited by
      #2

      @australien sagte in Script verbesserung:

      iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;

      Finde solche Variablennamen immer schwierig. Ich würde davon ausgehen, dass in der Variablen eine ID steht (also ein String). Und nicht ein spezifischer Wert. Liest sich komisch.

      Ansonsten könnte man das Script noch deutlich kürzen.

      🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
      🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
      📚 Meine inoffizielle ioBroker Dokumentation

      A 1 Reply Last reply
      0
      • A australien

        Hallo zusammen,

        ich fange gerade mit Javascript an und hätte da mal was zum Drüberschauen.

        Passt das so, oder wie kann man das Verbessern?

        danke für Eure Tipps

        /* 
        Wenn der Automower seine Unterkunft (Station) verlassen hat, darf die Bewässerung
        nicht anspringen.
        Bei der Bewässerung ist ein Shelly1 zwischen Steuerung und Pumpe eingebaut.
        Via MQTT wird das Relais (GrundwasserPumpe) geschaltet.
        
        Version:
            1.0 ist der Mäher zu hause, keine Bewässerung
            1.1 Bewässerung wird mit den letzten 24h Niederschlag aus Wetterstation vernetzt
        */
        
        const iDausloeser     = 'alias.0.Rasenflaeche.Station';
        const iDpumpe         = 'alias.0.Rasenflaeche.GrundwasserPumpe';
        var iDniederschlag24, iDniederschlag24_ts;
        
        iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
        iDniederschlag24_ts = getState('alias.0.Wetter.Doki.Niederschlag24h').ts;
        
         // triggert bei Mäher Aus- Einfahrt
        on({id: "alias.0.Rasenflaeche.Station", change: "any"}, function(dp) {
            iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
            if(iDniederschlag24 == 0){  /* Niederschlag die letzten 24h */
                if(getState(iDausloeser).val) {
                    setState(iDpumpe, true);
                } else {
                    setState(iDpumpe, false);
                    }
            } else {
                setState(iDpumpe, false);
                }
            console.log('Niederschlag --- Mäher  --->>> ' + iDniederschlag24 + ' mm/24h');
        });
        
        // triggert ber Niederschlag die letzten 24h
        on({id: "alias.0.Wetter.Doki.Niederschlag24h", change: "any"}, function(dp) {
            iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;
            
            console.log('Niederschlag  --- 24h  ---->>> ' + iDniederschlag24 + ' mm/24h');
            if(iDniederschlag24==0) {
                    setState(iDpumpe, true);
                    console.log('Niederschlag  --->  Pumpe an');
            } else {
                    setState(iDpumpe, false); 
                    console.log('Niederschlag  --->  Pumpe aus');
                    } 
        });
        
        
        paul53P Offline
        paul53P Offline
        paul53
        wrote on last edited by paul53
        #3

        @australien sagte: wie kann man das Verbessern?

        Ohne die Überschrift:

        const iDausloeser      = 'alias.0.Rasenflaeche.Station';
        const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
        const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
         
        var niederschlag24 = getState(iDniederschlag24).val;
         
         // triggert bei Mäher Aus- Einfahrt
        on(iDausloeser, function(dp) {
            setState(iDpumpe, niederschlag24 == 0 && dp.state.val);
            log('Niederschlag --- Mäher  --->>> ' + niederschlag24 + ' mm/24h');
        });
         
        // triggert ber Niederschlag die letzten 24h
        on(iDniederschlag24, function(dp) {
            niederschlag24 = dp.state.val;
            log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
            setState(iDpumpe, niederschlag24 == 0);
            log('Niederschlag  --->  Pumpe ' + niederschlag24 ? 'aus' : 'an');
        });
        

        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

        A 1 Reply Last reply
        0
        • paul53P paul53

          @australien sagte: wie kann man das Verbessern?

          Ohne die Überschrift:

          const iDausloeser      = 'alias.0.Rasenflaeche.Station';
          const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
          const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
           
          var niederschlag24 = getState(iDniederschlag24).val;
           
           // triggert bei Mäher Aus- Einfahrt
          on(iDausloeser, function(dp) {
              setState(iDpumpe, niederschlag24 == 0 && dp.state.val);
              log('Niederschlag --- Mäher  --->>> ' + niederschlag24 + ' mm/24h');
          });
           
          // triggert ber Niederschlag die letzten 24h
          on(iDniederschlag24, function(dp) {
              niederschlag24 = dp.state.val;
              log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
              setState(iDpumpe, niederschlag24 == 0);
              log('Niederschlag  --->  Pumpe ' + niederschlag24 ? 'aus' : 'an');
          });
          
          A Online
          A Online
          australien
          wrote on last edited by
          #4

          @paul53 danke dafür!
          da kann ich mir schon wieder was mitnehmen.

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

            @australien sagte in Script verbesserung:

            iDniederschlag24 = getState('alias.0.Wetter.Doki.Niederschlag24h').val;

            Finde solche Variablennamen immer schwierig. Ich würde davon ausgehen, dass in der Variablen eine ID steht (also ein String). Und nicht ein spezifischer Wert. Liest sich komisch.

            Ansonsten könnte man das Script noch deutlich kürzen.

            A Online
            A Online
            australien
            wrote on last edited by
            #5

            @haus-automatisierung stimmt, iD sollten Strings sein.
            Wie gesagt, bin am Anfang. Habe selbst mit 1991 mit dem Programmieren (turbo Pascal und turbo C) aufgehört und will jetzt zu Hause wieder etwas machen. Der Kopf soll ja was zu tun haben ;)

            1 Reply Last reply
            0
            • A australien

              @paul53 danke dafür!
              da kann ich mir schon wieder was mitnehmen.

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

              @australien sagte: wieder was mitnehmen.

              Wenn der "Niederschlag24h" auf 0 gehen kann, während gemäht wird, dann besser so:

              const iDausloeser      = 'alias.0.Rasenflaeche.Station';
              const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
              const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
               
              var niederschlag24 = getState(iDniederschlag24).val;
              var inStation = getState(iDausloeser).val;
               
               // triggert bei Mäher Aus- Einfahrt
              on(iDausloeser, function(dp) {
                  inStation = dp.state.val;
                  setState(iDpumpe, niederschlag24 == 0 && inStation);
                  log('Niederschlag --- Mäher  --->>> ' + niederschlag24 + ' mm/24h');
              });
               
              // triggert ber Niederschlag die letzten 24h
              on(iDniederschlag24, function(dp) {
                  niederschlag24 = dp.state.val;
                  log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
                  setState(iDpumpe, niederschlag24 == 0 && inStation);
                  log('Niederschlag  --->  Pumpe ' + niederschlag24 ? 'aus' : 'an');
              });
              

              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

              A 1 Reply Last reply
              0
              • paul53P paul53

                @australien sagte: wieder was mitnehmen.

                Wenn der "Niederschlag24h" auf 0 gehen kann, während gemäht wird, dann besser so:

                const iDausloeser      = 'alias.0.Rasenflaeche.Station';
                const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
                const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
                 
                var niederschlag24 = getState(iDniederschlag24).val;
                var inStation = getState(iDausloeser).val;
                 
                 // triggert bei Mäher Aus- Einfahrt
                on(iDausloeser, function(dp) {
                    inStation = dp.state.val;
                    setState(iDpumpe, niederschlag24 == 0 && inStation);
                    log('Niederschlag --- Mäher  --->>> ' + niederschlag24 + ' mm/24h');
                });
                 
                // triggert ber Niederschlag die letzten 24h
                on(iDniederschlag24, function(dp) {
                    niederschlag24 = dp.state.val;
                    log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
                    setState(iDpumpe, niederschlag24 == 0 && inStation);
                    log('Niederschlag  --->  Pumpe ' + niederschlag24 ? 'aus' : 'an');
                });
                
                A Online
                A Online
                australien
                wrote on last edited by
                #7

                @paul53 ja, kann er.

                paul53P 1 Reply Last reply
                0
                • A australien

                  @paul53 ja, kann er.

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

                  @australien sagte: ja, kann er

                  Noch besser mit einer Funktion:

                  const iDausloeser      = 'alias.0.Rasenflaeche.Station';
                  const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
                  const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
                   
                  var niederschlag24 = getState(iDniederschlag24).val;
                  var inStation = getState(iDausloeser).val;
                  
                  function grundwasser() {
                      let pumpe = niederschlag24 == 0 && inStation;
                      if(pumpe != getState(iDpumpe).val) {
                          setState(iDpumpe, pumpe);
                          log('Pumpe ' + (pumpe ? 'an' : 'aus'));
                      }
                  } 
                  
                  grundwasser(); // Skriptstart
                  
                   // triggert bei Mäher Aus- Einfahrt
                  on(iDausloeser, function(dp) {
                      inStation = dp.state.val;
                      log('Mäher ' + (inStation ? 'in Station' : 'mäht'));
                      grundwasser();
                  });
                   
                  // triggert ber Niederschlag die letzten 24h
                  on(iDniederschlag24, function(dp) {
                      niederschlag24 = dp.state.val;
                      log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
                      grundwasser();
                  });
                  

                  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

                  A 1 Reply Last reply
                  0
                  • paul53P paul53

                    @australien sagte: ja, kann er

                    Noch besser mit einer Funktion:

                    const iDausloeser      = 'alias.0.Rasenflaeche.Station';
                    const iDpumpe          = 'alias.0.Rasenflaeche.GrundwasserPumpe';
                    const iDniederschlag24 = 'alias.0.Wetter.Doki.Niederschlag24h';
                     
                    var niederschlag24 = getState(iDniederschlag24).val;
                    var inStation = getState(iDausloeser).val;
                    
                    function grundwasser() {
                        let pumpe = niederschlag24 == 0 && inStation;
                        if(pumpe != getState(iDpumpe).val) {
                            setState(iDpumpe, pumpe);
                            log('Pumpe ' + (pumpe ? 'an' : 'aus'));
                        }
                    } 
                    
                    grundwasser(); // Skriptstart
                    
                     // triggert bei Mäher Aus- Einfahrt
                    on(iDausloeser, function(dp) {
                        inStation = dp.state.val;
                        log('Mäher ' + (inStation ? 'in Station' : 'mäht'));
                        grundwasser();
                    });
                     
                    // triggert ber Niederschlag die letzten 24h
                    on(iDniederschlag24, function(dp) {
                        niederschlag24 = dp.state.val;
                        log('Niederschlag  --- 24h  ---->>> ' + niederschlag24 + ' mm/24h');
                        grundwasser();
                    });
                    
                    A Online
                    A Online
                    australien
                    wrote on last edited by
                    #9

                    @paul53 sehr übersichtlich nun! danke!

                    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

                    766

                    Online

                    32.4k

                    Users

                    81.5k

                    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