Skip to content
  • 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
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Doppeltes ausführen einer Funktion

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    207

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

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

Doppeltes ausführen einer Funktion

Doppeltes ausführen einer Funktion

Scheduled Pinned Locked Moved Skripten / Logik
8 Posts 3 Posters 844 Views
  • 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.
  • J Offline
    J Offline
    JoergC66
    wrote on last edited by
    #1

    Hallo,

    ich weiß -denn ich habe schon viel gesucht 😄 -dieses Thema gab es schon, aber keine angebotene Lösung hat funktioniert.

    Folgendes ganz simples Programm wird zweimal abgearbeitet, wenn ich mit dem Messenger "Telegram" einen Virtuellen Button der CCU drücke.

    on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT'}, function (obj) {
            console.log("Antasten= " + antasten);
      });
    

    in der Konsole steht dann:

    22:16:51.137 [info] javascript.0 script.js.Telegram.Alarmanlage: Antasten= true

    22:16:51.197 [info] javascript.0 script.js.Telegram.Alarmanlage: Antasten= true

    Alles was ich Netz gefunden habe z.B {id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT', change: "false"} habe ich erfolglos probiert.

    Wäre echt nett, wenn hier jemand nem alten Mann aufs Pferdchen helfen könnte 🙂

    Danke dafür und Gruß Jörg

    1 Reply Last reply
    0
    • blauholstenB Offline
      blauholstenB Offline
      blauholsten
      Developer
      wrote on last edited by
      #2

      @JoergC66:

      Hallo,

      ich weiß -denn ich habe schon viel gesucht 😄 -dieses Thema gab es schon, aber keine angebotene Lösung hat funktioniert.

      Folgendes ganz simples Programm wird zweimal abgearbeitet, wenn ich mit dem Messenger "Telegram" einen Virtuellen Button der CCU drücke.

      on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT'}, function (obj) {
              console.log("Antasten= " + antasten);
        });
      

      in der Konsole steht dann:

      22:16:51.137 [info] javascript.0 script.js.Telegram.Alarmanlage: Antasten= true

      22:16:51.197 [info] javascript.0 script.js.Telegram.Alarmanlage: Antasten= true

      Alles was ich Netz gefunden habe z.B {id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT', change: "false"} habe ich erfolglos probiert.

      Wäre echt nett, wenn hier jemand nem alten Mann aufs Pferdchen helfen könnte 🙂

      Danke dafür und Gruß Jörg `

      on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT'}, function (obj) {
              if(obj.state.val)console.log("Antasten= " + obj.state.val);
        });
      

      Woher kommt bei dir antasten

      Entwickler vom: - Viessman Adapter
      - Alarm Adapter

      1 Reply Last reply
      0
      • J Offline
        J Offline
        JoergC66
        wrote on last edited by
        #3

        Das ist nur eine Variable, die ich hier im Beispiel vergessen habe zu löschen, sie diente der Fehlersuche, hat also keine Bedeutung.

        Was macht das : obj.state.val ??

        1 Reply Last reply
        0
        • P Offline
          P Offline
          pix
          wrote on last edited by
          #4

          Hallo,

          ich spekuliere mal:

          Der "Tastendruck" auf der virtuellen Taste löste auch ein "Loslassen" aus. Das heißt, die Funktion wird beim Antasten, sowie beim Lostasten ausgelöst.

          Deine Bedingung ist durch die verwendete Kurzschreibweise ein Abo auf Veränderung des Wertes. Abonniere mal den Wert true und prüfe die Logausgabe:

          
          on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT', val: true}, function (obj) {
                  console.log("Antasten= " + obj.state.val);
            });
          
          

          Gruß

          Pix

          ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

          1 Reply Last reply
          0
          • J Offline
            J Offline
            JoergC66
            wrote on last edited by
            #5

            Erstmal vielen Dank für eure Mühen!!

            @pix Das hatte ich schon probiert, brachte keine Änderung.

            Die Antwort von blauholsten funktioniert.

            @blauholsten Was genau passiert da und warum ist das nötig?

            1 Reply Last reply
            0
            • P Offline
              P Offline
              pix
              wrote on last edited by
              #6

              Ich nehme die blauholstens Antwort mal vorweg:

              on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT'}, function (obj) {
              

              auf Änderung, Callback in Objekt mit Namen "obj"

               if(obj.state.val)console.log("Antasten= " + obj.state.val);
              

              Wenn der Wert des Objektes (obj.state.val) wahr ist (Kurzschreibweise von obj.state.val === true), dann erfolgt die Logausgabe des Wertes des Objektes.

              Also wird nur bei true ins Log geschrieben, nicht bei false.

              Gruß

              Pix

              ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

              1 Reply Last reply
              0
              • J Offline
                J Offline
                JoergC66
                wrote on last edited by
                #7

                Ah ja, ich verstehe …. ein bischen 😢

                Vielen Dank für die Erklärung.

                Doch dieses Problem verfolgt mich:

                on({id: "hm-rpc.0.KEQ0111275.2.PRESS_SHORT"/*HM-RC-X KEQ0111275:2.PRESS_SHORT*/}, function (obj) {	//Taste auf Fernbedienung
                    if(obj.state.val)
                        Alarmanlage_an();
                });
                
                function Alarmanlage_an(){
                    if (!getState("hm-rpc.0.KEQ0030837.1.STATE").val){		//Wenn Fensterkontakt "zu"
                        setState("hm-rega.0.1587"/*Alarmanlage*/, "1");		//Systemvariable der CCU auf 1 = Scharf
                    }     
                }
                
                on({id: "hm-rega.0.1587"/*Alarmanlage*/, change: "1"}, function (obj) {	//Wenn Alarmanlage scharf
                     if(obj.state.val){
                        request("http://192.168.2.144:50000/track=Die_Alarmanlage_ist_an.mp3");	//Tablet soll ansage mache- geht aber nur eine Zeitlang, dann bleibt alles stumm
                        sendTo("telegram", "send", {
                            text: (String('Alarmanlage ist ') + String((obj.state ? obj.state.val : "") ? 'an' : 'aus'))
                        });
                     }
                  });
                

                Das log-File sieht dann so aus:

                20:32:06.546	[info]	javascript.0 script.js.Telegram.Alarmanlage: getState(id=hm-rpc.0.KEQ0030837.1.STATE, timerId=0) => {"val":false,"ack":true,"ts":1517048026193,"q":0,"from":"system.adapter.hm-rpc.0","lc":1517048026193}
                20:32:06.548	[warn]	javascript.0 at Alarmanlage_an (script.js.Telegram.Alarmanlage:25:9)
                20:32:06.548	[warn]	javascript.0 at Object. (script.js.Telegram.Alarmanlage:15:9)
                20:32:06.548	[info]	javascript.0 script.js.Telegram.Alarmanlage: setForeignState(id=hm-rega.0.1587, state="1")
                20:32:06.548	[info]	javascript.0 script.js.Telegram.Alarmanlage: In dieser Funktion die Alarmanlage anschalten.
                20:32:06.565	[info]	javascript.0 script.js.Telegram.Alarmanlage: sendTo(adapter=telegram, cmd=send, msg={"text":"Alarmanlage ist an"})
                20:32:17.746	[info]	javascript.0 script.js.Telegram.Alarmanlage: sendTo(adapter=telegram, cmd=send, msg={"text":"Alarmanlage ist an"})
                

                Die Warnungen beziehen sich auf die Zeile mit dem "setState …"

                Also wieder diese blöde doppelte Ausführung. Heulsmiley

                Was mache ich denn nun wieder falsch?

                Gruß Jörg

                1 Reply Last reply
                0
                • blauholstenB Offline
                  blauholstenB Offline
                  blauholsten
                  Developer
                  wrote on last edited by
                  #8

                  @pix:

                  Ich nehme die blauholstens Antwort mal vorweg:

                  on({id: 'hm-rpc.0.BidCoS-RF.4.PRESS_SHORT'}, function (obj) {
                  

                  auf Änderung, Callback in Objekt mit Namen "obj"

                   if(obj.state.val)console.log("Antasten= " + obj.state.val);
                  

                  Wenn der Wert des Objektes (obj.state.val) wahr ist (Kurzschreibweise von obj.state.val === true), dann erfolgt die Logausgabe des Wertes des Objektes.

                  Also wird nur bei true ins Log geschrieben, nicht bei false.

                  Gruß

                  Pix `
                  Danke…

                  Entwickler vom: - Viessman Adapter
                  - Alarm Adapter

                  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

                  107

                  Online

                  32.4k

                  Users

                  81.3k

                  Topics

                  1.3m

                  Posts
                  Community
                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                  ioBroker Community 2014-2025
                  logo
                  • Login

                  • Don't have an account? Register

                  • Login or register to search.
                  • First post
                    Last post
                  0
                  • Recent
                  • Tags
                  • Unread 0
                  • Categories
                  • Unreplied
                  • Popular
                  • GitHub
                  • Docu
                  • Hilfe