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
    2.7k

  • 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.3k 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.
  • 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 Offline
          Karel PuhliK Offline
          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

            431

            Online

            32.6k

            Users

            82.3k

            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