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] Javascript in vis mit button triggern

NEWS

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

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

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

[Gelöst] Javascript in vis mit button triggern

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
16 Beiträge 6 Kommentatoren 815 Aufrufe 4 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.
  • Meister MopperM Meister Mopper

    @iob69 sagte in Javascript in vis mit button starten:

    Wie kann ich per Button (hab z.B. den JQui Button State versucht) ein Javascript starten?

    Das geht natürlich, aber es ist der falsche Ansatz für Lösungen.

    Skripte werden einmal gestartet und laufen im besten Fall bis zum nächsten reboot.

    Javascript ist eine ereignisorientierte Sprache, will heißen, es wird überwacht, ob sich etwas ändert.
    Wenn sich etwas ändert, wird eine Aktion aufgerufen.

    Somit ist das automatische Starten und Stoppen von Skripten eigentlich gar nicht vorgesehen und jeder sollte auf Basis dieser Vorgabe seine Skripte gestalten.

    Warum möchtest du ein Skript mit Button starten? Beschreibe doch bitte mal das Problem, und hier wirst du eine Lösung für das Problem bekommen, ohne ein Skript mit Button starten zu müssen.

    I Offline
    I Offline
    iob69
    schrieb am zuletzt editiert von iob69
    #4

    @meister-mopper
    danke für die Antwort,
    sorry, ich hab mich offenbar falsch ausgedrückt. Ich hab eigentlich nicht wirklich gemeint, das Script zu starten, sondern auf Eingaben zu reagieren/triggern.
    Das Script läuft natürlich. Die Idee ist eigentlich, Eingaben entgegenzunehmen und auf diese zu reagieren, z.B. Eine Liste erweitern, berechnungen zu machen usw.
    Das script muss ja schon laufen, wenn ich mit on(DP, .. reagieren will.

    Meister MopperM MartinPM 2 Antworten Letzte Antwort
    0
    • I iob69

      @meister-mopper
      danke für die Antwort,
      sorry, ich hab mich offenbar falsch ausgedrückt. Ich hab eigentlich nicht wirklich gemeint, das Script zu starten, sondern auf Eingaben zu reagieren/triggern.
      Das Script läuft natürlich. Die Idee ist eigentlich, Eingaben entgegenzunehmen und auf diese zu reagieren, z.B. Eine Liste erweitern, berechnungen zu machen usw.
      Das script muss ja schon laufen, wenn ich mit on(DP, .. reagieren will.

      Meister MopperM Abwesend
      Meister MopperM Abwesend
      Meister Mopper
      schrieb am zuletzt editiert von
      #5

      @iob69

      Okay, dann könnte der Titel dieses thread eine Modifikation erfahren :wink: .

      Proxmox und HA

      1 Antwort Letzte Antwort
      0
      • I iob69

        @meister-mopper
        danke für die Antwort,
        sorry, ich hab mich offenbar falsch ausgedrückt. Ich hab eigentlich nicht wirklich gemeint, das Script zu starten, sondern auf Eingaben zu reagieren/triggern.
        Das Script läuft natürlich. Die Idee ist eigentlich, Eingaben entgegenzunehmen und auf diese zu reagieren, z.B. Eine Liste erweitern, berechnungen zu machen usw.
        Das script muss ja schon laufen, wenn ich mit on(DP, .. reagieren will.

        MartinPM Online
        MartinPM Online
        MartinP
        schrieb am zuletzt editiert von MartinP
        #6

        @iob69 Hast Du in Deinem script "on(DP..."stehen, oder für den Datenpunkt den Pfad eines realen Datenpunktes eingesetzt?

        https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#on---subscribe-on-changes-or-updates-of-some-state

        Das funktioniert bei mir

        on('0_userdata.0.Puls-Test', async (data) => { 
        
            if (data.state.val)
              console.log('button pressed ');
            else
              console.log('button released');
        
        });
        
        
        

        0b65c228-0e71-45b4-9616-33791fde5ab6-grafik.png

        77d872fa-0237-42f2-915b-923f374b7f54-grafik.png

        Intel(R) Celeron(R) CPU N3000 @ 1.04GHz 8G RAM 480G SSD
        Virtualization : unprivileged lxc container (debian 12 on Proxmox 8.4.14)
        Linux pve 6.8.12-16-pve
        6 GByte RAM für den Container
        Fritzbox 6591 FW 8.03 (Vodafone Leih-Box)
        Remote-Access über Wireguard der Fritzbox

        I 1 Antwort Letzte Antwort
        0
        • I iob69

          Hallo,
          ich hab im Forum gesucht, aber nichts entsprechendes gefunden, wahrscheinlich suche ich nach falschen Wörtern.
          Wie kann ich per Button (hab z.B. den JQui Button State versucht) ein Javascript starten?
          Folgendes Versucht:
          dem Button ein DP zugeordnet. Diesem wird aber immer nur der Wert in "Wert:" zugeordnet, das heisst, dass das allererste mal, wenn ich den Button drücke, dem DP dieser Wert zugeordnet wird. Dies kann ich dann im Javascript auch mit on(DP) behandeln:

          on(DP, async (data) => { 
              console.log('button pressed');
          });
          

          Danach geht aber gar nichts mehr, weil der DP sich nicht mehr ändert.
          Triggert man da auf den sich ändernden Wert, also .val? könnte man auch auf die "Zuletzt geändert" oder "Zeitstempel" triggern?

          OliverIOO Offline
          OliverIOO Offline
          OliverIO
          schrieb am zuletzt editiert von OliverIO
          #7

          @iob69 sagte in Javascript in vis mit button starten:

          Dies kann ich dann im Javascript auch mit on(DP) behandeln:

          Wenn du von vis sprichst, dann gehe ich davon aus, das du den code im skript reiter in vis eingetragen hast?
          Dort gibt es diesen Befehl nicht. Der Befehl existiert nur im javascript-adapter und wird daher auf dem Server ausgeführt.

          Auf dem client/Browser ist so etwas auch möglich, aber etwas aufwändig.
          vis1 und vis2 sind unterschiedlich im verhalten, daher spreche ich nur von vis1
          dort werden die widgets dynamisch erzeugt. skript im skript reiter wird sofort ausgeführt nachdem die seite geladen wurde. uU exiatieren die widgets zu diesem zeitpunkt noch nicht. daher muss man darauf warten bis diese erzeugt wurden um dann eventhandler an irgendwelche widgets mit dran zu packen.

          auch bei datenpunkten ist es nicht so einfach. ziemlich zu beginn sucht vis alle datenpunkte zusammen und abonniert diese beim server. danach existieren diese abonnierte datenpunkte im array vis.states. das ist kein normales array, sondern eines das durch canJS verwaltet wird. dort kann man dann einen eventhandler anhängen, allerdings muss man aufpassen, da man sich da schnell ein memmory leak holen kann.

          versuche mal dein szenario genauer zu beschreiben, dann könnte man dir helfen, was in vis die beste strategie ist. insbesondere wo (server/browser) dein skript dann laufen soll um was zu tun.

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          MartinPM I 2 Antworten Letzte Antwort
          1
          • OliverIOO OliverIO

            @iob69 sagte in Javascript in vis mit button starten:

            Dies kann ich dann im Javascript auch mit on(DP) behandeln:

            Wenn du von vis sprichst, dann gehe ich davon aus, das du den code im skript reiter in vis eingetragen hast?
            Dort gibt es diesen Befehl nicht. Der Befehl existiert nur im javascript-adapter und wird daher auf dem Server ausgeführt.

            Auf dem client/Browser ist so etwas auch möglich, aber etwas aufwändig.
            vis1 und vis2 sind unterschiedlich im verhalten, daher spreche ich nur von vis1
            dort werden die widgets dynamisch erzeugt. skript im skript reiter wird sofort ausgeführt nachdem die seite geladen wurde. uU exiatieren die widgets zu diesem zeitpunkt noch nicht. daher muss man darauf warten bis diese erzeugt wurden um dann eventhandler an irgendwelche widgets mit dran zu packen.

            auch bei datenpunkten ist es nicht so einfach. ziemlich zu beginn sucht vis alle datenpunkte zusammen und abonniert diese beim server. danach existieren diese abonnierte datenpunkte im array vis.states. das ist kein normales array, sondern eines das durch canJS verwaltet wird. dort kann man dann einen eventhandler anhängen, allerdings muss man aufpassen, da man sich da schnell ein memmory leak holen kann.

            versuche mal dein szenario genauer zu beschreiben, dann könnte man dir helfen, was in vis die beste strategie ist. insbesondere wo (server/browser) dein skript dann laufen soll um was zu tun.

            MartinPM Online
            MartinPM Online
            MartinP
            schrieb am zuletzt editiert von
            #8

            @oliverio sagte in Javascript in vis mit button starten:

            Wenn du von vis sprichst, dann gehe ich davon aus, das du den code im skript reiter in vis eingetragen hast?

            So weit habe ich gar nicht gedacht ....

            Intel(R) Celeron(R) CPU N3000 @ 1.04GHz 8G RAM 480G SSD
            Virtualization : unprivileged lxc container (debian 12 on Proxmox 8.4.14)
            Linux pve 6.8.12-16-pve
            6 GByte RAM für den Container
            Fritzbox 6591 FW 8.03 (Vodafone Leih-Box)
            Remote-Access über Wireguard der Fritzbox

            1 Antwort Letzte Antwort
            0
            • MartinPM MartinP

              @iob69 Hast Du in Deinem script "on(DP..."stehen, oder für den Datenpunkt den Pfad eines realen Datenpunktes eingesetzt?

              https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#on---subscribe-on-changes-or-updates-of-some-state

              Das funktioniert bei mir

              on('0_userdata.0.Puls-Test', async (data) => { 
              
                  if (data.state.val)
                    console.log('button pressed ');
                  else
                    console.log('button released');
              
              });
              
              
              

              0b65c228-0e71-45b4-9616-33791fde5ab6-grafik.png

              77d872fa-0237-42f2-915b-923f374b7f54-grafik.png

              I Offline
              I Offline
              iob69
              schrieb am zuletzt editiert von
              #9

              @martinp
              Hallo,
              natürlich hab ich als DP den Datenpunkt hinterlegt. Das ist eine konstante:
              const DPTestPunkt = '0_userdata.0.DPTestPunkt';

              const DPTestPunkt = '0_userdata.0.DPTestPunkt';
              

              Es funktioniert ja auch, aber nur beim ersten mal, wenn der Datenpunkt geändert wird.
              Was für ein Knopf-Widget hast du denn verwendet und wo has du den Datenpunkt eingetragen?

              OliverIOO MartinPM 2 Antworten Letzte Antwort
              0
              • I iob69

                @martinp
                Hallo,
                natürlich hab ich als DP den Datenpunkt hinterlegt. Das ist eine konstante:
                const DPTestPunkt = '0_userdata.0.DPTestPunkt';

                const DPTestPunkt = '0_userdata.0.DPTestPunkt';
                

                Es funktioniert ja auch, aber nur beim ersten mal, wenn der Datenpunkt geändert wird.
                Was für ein Knopf-Widget hast du denn verwendet und wo has du den Datenpunkt eingetragen?

                OliverIOO Offline
                OliverIOO Offline
                OliverIO
                schrieb am zuletzt editiert von
                #10

                @iob69
                dann schreibe den datenpunkt selbst wieder zurück?
                ich weiß jetzt nicht ob es ein widget gibt, das erst auf true/1 und dann nach einer gewissen zeit wieder auf false/0

                aber mit setState kannst du selbst den datenpunkt wieder zurückstellen

                Meine Adapter und Widgets
                TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                Links im Profil

                I 1 Antwort Letzte Antwort
                0
                • I iob69

                  @martinp
                  Hallo,
                  natürlich hab ich als DP den Datenpunkt hinterlegt. Das ist eine konstante:
                  const DPTestPunkt = '0_userdata.0.DPTestPunkt';

                  const DPTestPunkt = '0_userdata.0.DPTestPunkt';
                  

                  Es funktioniert ja auch, aber nur beim ersten mal, wenn der Datenpunkt geändert wird.
                  Was für ein Knopf-Widget hast du denn verwendet und wo has du den Datenpunkt eingetragen?

                  MartinPM Online
                  MartinPM Online
                  MartinP
                  schrieb am zuletzt editiert von
                  #11

                  @iob69 siehe Screenshot.
                  Das Script ist aber im Javascript Adapter, und nicht im Vis view

                  Intel(R) Celeron(R) CPU N3000 @ 1.04GHz 8G RAM 480G SSD
                  Virtualization : unprivileged lxc container (debian 12 on Proxmox 8.4.14)
                  Linux pve 6.8.12-16-pve
                  6 GByte RAM für den Container
                  Fritzbox 6591 FW 8.03 (Vodafone Leih-Box)
                  Remote-Access über Wireguard der Fritzbox

                  1 Antwort Letzte Antwort
                  1
                  • BananaJoeB Online
                    BananaJoeB Online
                    BananaJoe
                    Most Active
                    schrieb am zuletzt editiert von BananaJoe
                    #12

                    @iob69 sagte in Javascript in vis mit button starten:

                    Triggert man da auf den sich ändernden Wert, also .val?

                    Also, Wenn ich über einen Button / Widget ein Skript anstoße:

                    • Der Button auf der VIS, da nehme ich einen "true/false" Button. Das Bulb-Widget z.B.
                    • der auf einen entsprechenden Datenpunkt unterhalb von 0_userdata.0 verweist.
                    • Der Button schaltet den Datenpunkt dann also zwischen True und False hin und her.
                    • Normalzustand ist False.
                    • Mein Skript reagiert wenn der Datenpunkt auf True springt
                    • Macht was es soll, setzt den Datenpunkt durch den es ausgelöst hat aber auch wieder nach x Millisekunden (ich nehme meist 500 bis 700) auf False.

                    Dadurch "reagiert" der Button und ich weis das das Skript gestartet hat.

                    Edit: hier wie ich es gemacht habe, allerdings mit Blockly:
                    https://forum.iobroker.net/topic/78000/vis2-vis-inventwo-taster-und-link-erstellen/8?_=1732747374922

                    ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                    1 Antwort Letzte Antwort
                    1
                    • OliverIOO OliverIO

                      @iob69 sagte in Javascript in vis mit button starten:

                      Dies kann ich dann im Javascript auch mit on(DP) behandeln:

                      Wenn du von vis sprichst, dann gehe ich davon aus, das du den code im skript reiter in vis eingetragen hast?
                      Dort gibt es diesen Befehl nicht. Der Befehl existiert nur im javascript-adapter und wird daher auf dem Server ausgeführt.

                      Auf dem client/Browser ist so etwas auch möglich, aber etwas aufwändig.
                      vis1 und vis2 sind unterschiedlich im verhalten, daher spreche ich nur von vis1
                      dort werden die widgets dynamisch erzeugt. skript im skript reiter wird sofort ausgeführt nachdem die seite geladen wurde. uU exiatieren die widgets zu diesem zeitpunkt noch nicht. daher muss man darauf warten bis diese erzeugt wurden um dann eventhandler an irgendwelche widgets mit dran zu packen.

                      auch bei datenpunkten ist es nicht so einfach. ziemlich zu beginn sucht vis alle datenpunkte zusammen und abonniert diese beim server. danach existieren diese abonnierte datenpunkte im array vis.states. das ist kein normales array, sondern eines das durch canJS verwaltet wird. dort kann man dann einen eventhandler anhängen, allerdings muss man aufpassen, da man sich da schnell ein memmory leak holen kann.

                      versuche mal dein szenario genauer zu beschreiben, dann könnte man dir helfen, was in vis die beste strategie ist. insbesondere wo (server/browser) dein skript dann laufen soll um was zu tun.

                      I Offline
                      I Offline
                      iob69
                      schrieb am zuletzt editiert von iob69
                      #13

                      @oliverio
                      Also ich hab in vis (nicht vis2) einen Button JQui Button State reingepackt und unter allgemein folgendes eingetragen:
                      Object ID: den Datenpunkt auf den ich triggern will
                      Wert: '1' Irgendwas muss man ja schreiben, wenn man den Datenpunkt verändern will?
                      f8430d3d-b9e3-4a54-9341-9709e7a6aa92-grafik.png

                      Dann hab ich in Javascript (nicht in vis) auf diesen Datenpunkt getriggert eben wie folgt:

                      on(DP, async (data) => { 
                          console.log('button pressed');
                      });
                      

                      Eigentlich funktioniert es ja auch aber nur einmal, (ich nehme an, weil sich der Wert 1 nicht mehr ändert, kriege ich kein event mehr). Ändere ich den Datenpunk von Hand (in den Objekten) auf 0 wird wieder getriggert, (und nochmal beim click auf den Button auf 1) danach ist wieder schluss. Deshalb die Frage, ob man auch eben auf "Zuletzt geändert" oder "Zeitstempel"
                      triggern kann. In den Objekten kann man diese Werte doch abfragen und soviel ich weiss, wenn man einen wert eines DP abfragen will muss man das mit getState(DP).val; tun. gibt es auch einen getState(DP).changed ?

                      Aber vielleicht muss ich beim Button was anderes oder woanders was noch eintragen? Oder ich hab den falschen button?

                      Betreffend Javascript in vis und im Adapter:
                      Bin relativ neu hier und ich hab auch schon in der vis zu scripten versucht, aber ich glaube, dort ist alles global, also auch unter den verschiedenen views. Da gibt es wohl wie keine Kapselung? Aber als Programmierer in anderen Sprachen fühl ich mich im Adapter wohler, obwohl da für mich auch nicht ganz klar ist, ob und wie da Kapselung existiert. Manchmal krieg ich eine Meldung (rot unterstrichen), dass eine Variable schon existiert, aber teilweise selbst dann, wenn ich die in keinem anderen Script verwende. Da bin ich sehr unsicher.

                      Jedenfalls war mir der Unterschied nicht klar, dass im Adapter die sache auf dem Server und in der vis auf dem client/browser ausgeführt wird. Ist ja eigentlich logisch. Und ich nehme an, die Schnittstelle sind dann eben die Datenpunkte... Jedenfalls wieder was gelernt. :-)

                      OliverIOO 1 Antwort Letzte Antwort
                      0
                      • I iob69

                        @oliverio
                        Also ich hab in vis (nicht vis2) einen Button JQui Button State reingepackt und unter allgemein folgendes eingetragen:
                        Object ID: den Datenpunkt auf den ich triggern will
                        Wert: '1' Irgendwas muss man ja schreiben, wenn man den Datenpunkt verändern will?
                        f8430d3d-b9e3-4a54-9341-9709e7a6aa92-grafik.png

                        Dann hab ich in Javascript (nicht in vis) auf diesen Datenpunkt getriggert eben wie folgt:

                        on(DP, async (data) => { 
                            console.log('button pressed');
                        });
                        

                        Eigentlich funktioniert es ja auch aber nur einmal, (ich nehme an, weil sich der Wert 1 nicht mehr ändert, kriege ich kein event mehr). Ändere ich den Datenpunk von Hand (in den Objekten) auf 0 wird wieder getriggert, (und nochmal beim click auf den Button auf 1) danach ist wieder schluss. Deshalb die Frage, ob man auch eben auf "Zuletzt geändert" oder "Zeitstempel"
                        triggern kann. In den Objekten kann man diese Werte doch abfragen und soviel ich weiss, wenn man einen wert eines DP abfragen will muss man das mit getState(DP).val; tun. gibt es auch einen getState(DP).changed ?

                        Aber vielleicht muss ich beim Button was anderes oder woanders was noch eintragen? Oder ich hab den falschen button?

                        Betreffend Javascript in vis und im Adapter:
                        Bin relativ neu hier und ich hab auch schon in der vis zu scripten versucht, aber ich glaube, dort ist alles global, also auch unter den verschiedenen views. Da gibt es wohl wie keine Kapselung? Aber als Programmierer in anderen Sprachen fühl ich mich im Adapter wohler, obwohl da für mich auch nicht ganz klar ist, ob und wie da Kapselung existiert. Manchmal krieg ich eine Meldung (rot unterstrichen), dass eine Variable schon existiert, aber teilweise selbst dann, wenn ich die in keinem anderen Script verwende. Da bin ich sehr unsicher.

                        Jedenfalls war mir der Unterschied nicht klar, dass im Adapter die sache auf dem Server und in der vis auf dem client/browser ausgeführt wird. Ist ja eigentlich logisch. Und ich nehme an, die Schnittstelle sind dann eben die Datenpunkte... Jedenfalls wieder was gelernt. :-)

                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        schrieb am zuletzt editiert von OliverIO
                        #14

                        @iob69

                        also du hast 2 möglichkeiten.

                        1. du nimmst das jqui button state und reagierst auf die Änderung im Datenpunkt.
                          wie du es schon hast
                        on(DP, async (data) => { 
                            console.log('button pressed');
                            // hier kommt deine eigene logik rein
                            //
                            // am ende dann den wert wieder auf false setzen, 
                            // das der knopf dann erneut gedrückt werden kann 
                            // bzw du dann auch die Änderung des wertes mitbekommt.
                            setState(DP,false);  
                        });
                        

                        die andere Möglichkeit wäre ein widget zu nehmen, das als Taster fungiert.
                        da habe ich in der Standarinstallation erst mal nur "hqwidgets On/Off" gefunden.
                        Da kann man Taster ankreuzen, dann setzt sich im Hintergrund der Status nach einer weile zurück. Aber da macht das widget nix anderes, wie du auf der Serverseite.

                        Nachtrag wegen nächstem Post.
                        Du musst eigentlich keine Zeitverzögerung beachten, da du ja erst am Ende des Skripts den Wert zurücksetzt.
                        ERst wenn du Zeitkritische Prozesse hast und ggfs der Nutzer da mehrfach in kurzer Zeit den Knopf drückt, dann kann man weiterschauen.
                        Aber du hast ja selber festgestellt, das dein Skript nur eine Änderung mitbekommst. ERst mit Schreiben des Statuses kannst du erneut wieder aufgerufen werdne.

                        Meine Adapter und Widgets
                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                        Links im Profil

                        1 Antwort Letzte Antwort
                        1
                        • OliverIOO OliverIO

                          @iob69
                          dann schreibe den datenpunkt selbst wieder zurück?
                          ich weiß jetzt nicht ob es ein widget gibt, das erst auf true/1 und dann nach einer gewissen zeit wieder auf false/0

                          aber mit setState kannst du selbst den datenpunkt wieder zurückstellen

                          I Offline
                          I Offline
                          iob69
                          schrieb am zuletzt editiert von
                          #15

                          @oliverio
                          @BananaJoe
                          Ja ich versuch das mal mit dem zurückschreiben. Muss da nur noch mal sehen, wie das mit der Zeitverzögerung geht.

                          I 1 Antwort Letzte Antwort
                          0
                          • I iob69

                            @oliverio
                            @BananaJoe
                            Ja ich versuch das mal mit dem zurückschreiben. Muss da nur noch mal sehen, wie das mit der Zeitverzögerung geht.

                            I Offline
                            I Offline
                            iob69
                            schrieb am zuletzt editiert von
                            #16

                            @oliverio
                            @BananaJoe
                            Ok, jetzt klappt es auch mit meinem Button, vielen Dank :-)

                            Musste noch eine Abfrage einbauen, damit die funktion auch nur auf die set-Action reagiert und nicht zweimal:

                            on(DPTestPunkt, async (data) => { 
                                if (getState(DPTestPunkt).val) {
                                    console.log('button pressed');
                                    setTimeout(function() {
                                        setState(DPTestPunkt , false);
                                    }, 400);    
                                }
                            });
                            
                            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

                            821

                            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