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 es gab Mal ein Problem mit dem # Zeichen, wenn 2 id`s das hatten

      Weiß nicht, ob das behoben wurde

      Daher teste deine Formel Mal mit einer id als 2ten Wert ohne das # Zeichen

      Du kannst auch die runtime in Chrome öffnen und die Entwicklertools öffnen, im Reiter console kannst du dann bei einem refresh der Seite die Fehler ansehen

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

        @liv-in-sky
        danke für deine Antwort.

        Ich habe mal einen anderen Datenpunkt ohne # verwendet. Das hat keine Unterschied gemacht.
        In den Entwicklertools habe ich einige Hinweise erhalten:

        8b6a6e21-c6d2-47ec-be46-aafaf05e3ee6-image.png

        scheinbar kann er den Doppelpunkt nicht interpretieren?

        Grüße
        Intruminator

        liv-in-sky 2 Replies Last reply Reply Quote 0
        • 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

                              805
                              Online

                              31.7k
                              Users

                              79.8k
                              Topics

                              1.3m
                              Posts

                              5
                              14
                              774
                              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