Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. [gelöst] HTML-Widget - Werte addieren

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [gelöst] HTML-Widget - Werte addieren

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @Intruminator last edited by

      @intruminator hast du mal id's getestet - also wert1 und 2 ohne diesen # im id-namen - mach dir einfach 2 testdatenpunkte

      ichdenke es ist nicht der doppelpunkt, sondern der id-name

      eine lösung wäre z.b. ein alias zu nehmen - falls es das # problem ist

      I 1 Reply Last reply Reply Quote 1
      • liv-in-sky
        liv-in-sky @Intruminator last edited by liv-in-sky

        @intruminator wieso eigentlich:

        (+wert1)+(+wert2))
        

        und nicht

        wert1+wert2
        
        OliverIO 1 Reply Last reply Reply Quote 0
        • OliverIO
          OliverIO @liv-in-sky last edited by

          @liv-in-sky sagte in HTML-Widget - Werte addieren:

          wert1+wert2

          ja das ist richtig. zur Sicherheit müssen die Werte auch vorher in eine Zahl umgewandelt werden, da die Werte dort meist nur als String ankommen (parseInt oder parseFloat)

          Die Bindings haben sozusagen 2 verschiedene Modi:

          1. Notation ohne Variablenzuweisung: Hier kann als Befehl zur Addition +100 angegeben werden
          2. Notation mit Variablenzuordnung: Hier werden die nachfolgende Befehle als javascriptanweisungen interpretiert und dann gehen die ganzen Befehle, wie sie in der Binding-Doku angegeben worden sind nicht mehr und es muss alles mit javascriptanweisungen angegeben werden.
          liv-in-sky 1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky @OliverIO last edited by

            @oliverio danke - man lernt nie aus mit iobroker

            1 Reply Last reply Reply Quote 0
            • I
              Intruminator @liv-in-sky last edited by Intruminator

              @liv-in-sky
              Ah, super Idee.
              Zum einen werde ich mal zwei Test-Objekte (dann ohne #) erstellen und ausprobieren.

              Dann schaue ich mir auch die Idee mit den Alias an. Dachte erst, dass ich die ID der shelly Geräte ja nicht ändern kann (mit #).

              @OliverIO
              Das Beispiel hatte ich aus dem oben genannten Thread einfach hergenommen.

              Grüße!

              I 1 Reply Last reply Reply Quote 0
              • I
                Intruminator @Intruminator last edited by

                Guten Abend!

                1. Mit den Testobjekten hat es direkt und korrekt funktioniert.

                2. Die Alias funktionieren super, da habe ich wieder was Neues im ioBroker gelernt! 😀
                  Demnach gibt es bei der Interpretation der # in den Namen der shelly-Geräte Probleme.

                3. Folgende Lösungen konnte ich nun erfolgreich testen:

                3.1

                {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; ((+wert1)+(+wert2)+(+wert3)+(+wert4))}
                

                Gibt je nach Wert dann manchmal zu viele Nachkommastellen raus: c4c3c038-751f-48de-bd06-87f20a965236-image.png

                3.2

                Aus obigen Beitrag hatte @Peoples darauf hingewiesen, dass man es mit parseInt() "sauberer" realisieren kann. Daher habe ich die Idee angewendet und auf meine Wünsche angepasst.

                {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; (parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)+parseFloat(wert4)).toFixed(2)}
                

                --> da parseInt() mir ganze Zahlen zurückgibt, habe ich stattdessen parseFloat() genutzt
                --> um die Nachkommastellen unter 3.1 auf maximal zwei zu reduzieren habe ich toFixed(2) verwendet

                Das Ergebnis ist perfekt:

                4d7f7efe-ef99-4fdb-888a-6de8c70c3d76-image.png

                Danke für eure superschnelle Hilfe. Ich hoffe mein Beitrag kann auch anderen Usern von Nutzen sein!

                Ganz liebe Grüße
                Intruminator 😄

                M 1 Reply Last reply Reply Quote 1
                • M
                  Micha3004 @Intruminator last edited by

                  @intruminator sagte in [gelöst] HTML-Widget - Werte addieren:

                  Guten Abend!

                  1. Mit den Testobjekten hat es direkt und korrekt funktioniert.

                  2. Die Alias funktionieren super, da habe ich wieder was Neues im ioBroker gelernt! 😀
                    Demnach gibt es bei der Interpretation der # in den Namen der shelly-Geräte Probleme.

                  3. Folgende Lösungen konnte ich nun erfolgreich testen:

                  3.1

                  {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; ((+wert1)+(+wert2)+(+wert3)+(+wert4))}
                  

                  Gibt je nach Wert dann manchmal zu viele Nachkommastellen raus: c4c3c038-751f-48de-bd06-87f20a965236-image.png

                  3.2

                  Aus obigen Beitrag hatte @Peoples darauf hingewiesen, dass man es mit parseInt() "sauberer" realisieren kann. Daher habe ich die Idee angewendet und auf meine Wünsche angepasst.

                  {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; (parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)+parseFloat(wert4)).toFixed(2)}
                  

                  --> da parseInt() mir ganze Zahlen zurückgibt, habe ich stattdessen parseFloat() genutzt
                  --> um die Nachkommastellen unter 3.1 auf maximal zwei zu reduzieren habe ich toFixed(2) verwendet

                  Das Ergebnis ist perfekt:

                  4d7f7efe-ef99-4fdb-888a-6de8c70c3d76-image.png

                  Danke für eure superschnelle Hilfe. Ich hoffe mein Beitrag kann auch anderen Usern von Nutzen sein!

                  Ganz liebe Grüße
                  Intruminator 😄

                  Kann mir jemand sagen wie ich es nun noch im Code hinbekomme, die errechnete Summe mal XXX € zurechnen?

                  OliverIO 1 Reply Last reply Reply Quote 0
                  • OliverIO
                    OliverIO @Micha3004 last edited by

                    @micha3004

                    {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; ((parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)+parseFloat(wert4)).toFixed(2))*0.123}
                    

                    um die Formel zur Sicherheit noch eine Klammer und dann multiplizieren.
                    Hier im Beispiel 0.123

                    M 1 Reply Last reply Reply Quote 0
                    • M
                      Micha3004 @OliverIO last edited by

                      @oliverio sagte in [gelöst] HTML-Widget - Werte addieren:

                      @micha3004

                      {wert1:alias.0.alias-tvbox; wert2:alias.0.alias-blakon-led; wert3:alias.0.alias-pc-1; wert4:alias.0.alias-pc-2; ((parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)+parseFloat(wert4)).toFixed(2))*0.123}
                      

                      um die Formel zur Sicherheit noch eine Klammer und dann multiplizieren.
                      Hier im Beispiel 0.123

                      habe es versucht leider wird ein falscher Wert ausgegeben

                      {wert1:alias.0.Shelly.Lichterkette_Wohnzimmer.Umrechnung_gesamt; wert2:alias.0.Shelly.TV_Wand.Umrechnung_gesamt; wert3:alias.0.Shelly.Waschmaschine.Umrechnung_gesamt; ((parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)).toFixed(2))*0,50}

                      OliverIO C 2 Replies Last reply Reply Quote 0
                      • OliverIO
                        OliverIO @Micha3004 last edited by

                        @micha3004
                        was soll ich jetzt hier machen?
                        du hast den falschen wert nicht genannt.
                        du hast die Inhalte der anderen Datenpunktinhalte nicht genannt (wert1,2,3)
                        was hat es ohne die anpassung angezeigt?
                        wie sollte ich jetzt hier irgendwas überprüfen?
                        wenn es was falsch rechnet, dann ist was an der formel falsch.

                        1 Reply Last reply Reply Quote 0
                        • C
                          Chrunchy @Micha3004 last edited by

                          @micha3004 sagte in [gelöst] HTML-Widget - Werte addieren:

                          habe es versucht leider wird ein falscher Wert ausgegeben

                          {wert1:alias.0.Shelly.Lichterkette_Wohnzimmer.Umrechnung_gesamt; wert2:alias.0.Shelly.TV_Wand.Umrechnung_gesamt; wert3:alias.0.Shelly.Waschmaschine.Umrechnung_gesamt; ((parseFloat(wert1)+parseFloat(wert2)+parseFloat(wert3)).toFixed(2))*0,50}

                          Soweit ich weiß, muss das Dezimaltrennzeichen ein Punkt sein, kein Komma.

                          1 Reply Last reply Reply Quote 0
                          • First post
                            Last post

                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          593
                          Online

                          31.6k
                          Users

                          79.6k
                          Topics

                          1.3m
                          Posts

                          5
                          14
                          710
                          Loading More Posts
                          • Oldest to Newest
                          • Newest to Oldest
                          • Most Votes
                          Reply
                          • Reply as topic
                          Log in to reply
                          Community
                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                          The ioBroker Community 2014-2023
                          logo