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.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.2k

[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.

    HomoranH Nicht stören
    HomoranH Nicht stören
    Homoran
    Global Moderator Administrators
    schrieb am zuletzt editiert von Homoran
    #3

    @meister-mopper Er scheint schon ein laufendes Skript triggern zu wollen.

    Leider kann ich kein js und kann @iob69 die Frage nach dem Befehl um auf Aktualisierung zu triggern nicht geben :-(

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    1 Antwort Letzte Antwort
    1
    • 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

                              749

                              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