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. JavaScript
  5. Script funzt nicht mehr

NEWS

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

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

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

Script funzt nicht mehr

Script funzt nicht mehr

Scheduled Pinned Locked Moved JavaScript
22 Posts 7 Posters 1.8k Views 6 Watching
  • 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.
  • OliverIOO OliverIO

    @jprisum-de
    und das soll schon mal funktioniert haben?

    1. die Bezeichnung von reservierten Wörtern oder Klassen zu verwenden ist keine gute Idee
      array ist bei dir zwar klein geschrieben. Array ist aber ein reserviertes wort. verwende dann liebe a oder ar oder einen sinnigeren namen, das man weiß was da drin ist.

    2. array ist nicht deklariert du musst in zeile 8 ein var oder let davor schreiben

    CodierknechtC Offline
    CodierknechtC Offline
    Codierknecht
    Developer Most Active
    wrote on last edited by Codierknecht
    #7

    @jprisum-de
    Achtung, hier kommt der Erbsenzähler:

    @oliverio sagte in Script funzt nicht mehr:

    verwende dann liebe a oder ar

    besser nicht: https://github.com/Droogans/unmaintainable-code

    @oliverio sagte in Script funzt nicht mehr:

    oder einen sinnigeren namen, das man weiß was da drin ist

    Das auf jeden Fall. Etwas sprechendes, das zum Einen mitteilt was enthalten ist und zum Anderen ggf. auch gleich erkennen lässt dass da ein Array gebaut wird. Also sowas wie statesArrayoder etwas in der Art.
    Und da die Werte ja auch hier schon 2x verwendet werden und sich erst zur Laufzeit mit dem passenden Input ergibt, dass array[21] den Wert und array[22] die dazu passende Einheit darstellt, kann man das dann auch vor der Verwendung in eine lesbare Form - z.B. ein Objekt packen.

    RunScript kann man auch diskutieren, denn diese Funktion startet ja nix. Ich persönlich würde das sogar in 2 Funktionen aufteilen: getValues und writeData ... zum Beispiel.

    Und dann kommt ja fast garantiert die Diskussion: Wozu? Läuft doch!
    Ja - aber wie man an diesem Beispiel schön sehen kann: Es läuft dann ... und nach ein paar Jahren (wahlweise wenige Wochen) schaut sich jemand den Code an und versteht nur Bahnhof.
    Nicht selten denkt man sich "Welcher Horst hat das denn verbrochen?" ... um dann festzustellen "Upps, ist ja mein eigener Code". Ich spreche da aus Erfahrung 😉

    @jprisum-de
    Mit der reinen Funktionsfähigkeit hat meine Auslassung natürlich nix zu tun.
    Sobald Du das reservierte Wort array durch etwas sinnhafteres ersetzt und ein var davor schreibst, sollte das Script wieder funktionieren.

    Aber die nächste Änderung kommt bestimmt ...
    1.) Jeder Code muss irgendwann gewartet werden
    2.) Jeder nicht triviale Code enthält mindesten 1 Bug

    P.S.:
    Warum schreibst Du eigentlich den Wert zusammen mit der Einheit als string weg? Damit kann man ja später nicht mehr rechnen.
    Ich würde nur den reinen Wert in einen numerischen DP schreiben. Die Einheit sollte eigentlich fix sein und kann am DP eingestellt werden.

    "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

    Proxmox 8.2.4 LXC|8 GB|Core i7-6700
    HmIP|ZigBee|Tasmota|Unifi + dies & das
    Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

    J 1 Reply Last reply
    0
    • OliverIOO OliverIO

      @jprisum-de
      und das soll schon mal funktioniert haben?

      1. die Bezeichnung von reservierten Wörtern oder Klassen zu verwenden ist keine gute Idee
        array ist bei dir zwar klein geschrieben. Array ist aber ein reserviertes wort. verwende dann liebe a oder ar oder einen sinnigeren namen, das man weiß was da drin ist.

      2. array ist nicht deklariert du musst in zeile 8 ein var oder let davor schreiben

      J Offline
      J Offline
      jprisum.de
      wrote on last edited by
      #8

      @oliverio
      Vielen lieben Dank,
      es war das "var" dies gesetzt und schon funzt es wieder

      1 Reply Last reply
      0
      • CodierknechtC Codierknecht

        @jprisum-de
        Achtung, hier kommt der Erbsenzähler:

        @oliverio sagte in Script funzt nicht mehr:

        verwende dann liebe a oder ar

        besser nicht: https://github.com/Droogans/unmaintainable-code

        @oliverio sagte in Script funzt nicht mehr:

        oder einen sinnigeren namen, das man weiß was da drin ist

        Das auf jeden Fall. Etwas sprechendes, das zum Einen mitteilt was enthalten ist und zum Anderen ggf. auch gleich erkennen lässt dass da ein Array gebaut wird. Also sowas wie statesArrayoder etwas in der Art.
        Und da die Werte ja auch hier schon 2x verwendet werden und sich erst zur Laufzeit mit dem passenden Input ergibt, dass array[21] den Wert und array[22] die dazu passende Einheit darstellt, kann man das dann auch vor der Verwendung in eine lesbare Form - z.B. ein Objekt packen.

        RunScript kann man auch diskutieren, denn diese Funktion startet ja nix. Ich persönlich würde das sogar in 2 Funktionen aufteilen: getValues und writeData ... zum Beispiel.

        Und dann kommt ja fast garantiert die Diskussion: Wozu? Läuft doch!
        Ja - aber wie man an diesem Beispiel schön sehen kann: Es läuft dann ... und nach ein paar Jahren (wahlweise wenige Wochen) schaut sich jemand den Code an und versteht nur Bahnhof.
        Nicht selten denkt man sich "Welcher Horst hat das denn verbrochen?" ... um dann festzustellen "Upps, ist ja mein eigener Code". Ich spreche da aus Erfahrung 😉

        @jprisum-de
        Mit der reinen Funktionsfähigkeit hat meine Auslassung natürlich nix zu tun.
        Sobald Du das reservierte Wort array durch etwas sinnhafteres ersetzt und ein var davor schreibst, sollte das Script wieder funktionieren.

        Aber die nächste Änderung kommt bestimmt ...
        1.) Jeder Code muss irgendwann gewartet werden
        2.) Jeder nicht triviale Code enthält mindesten 1 Bug

        P.S.:
        Warum schreibst Du eigentlich den Wert zusammen mit der Einheit als string weg? Damit kann man ja später nicht mehr rechnen.
        Ich würde nur den reinen Wert in einen numerischen DP schreiben. Die Einheit sollte eigentlich fix sein und kann am DP eingestellt werden.

        J Offline
        J Offline
        jprisum.de
        wrote on last edited by
        #9

        @codierknecht

        Wie gesagt habe ich das Script vor Jahren mal abgeschrieben und zum laufen gebracht (man war ich Stolz :-p) aber so wie du schon geschrieben hast und da gebe ich Dir recht, kann es keine S.... mehr lesen, Asche auf mein Haupt, ich bin nur Abtipper und leider kein Programmierer, freu mich dafür um so mehr, wenn sich Leute wir Ihr es mir dann versuchen beizubringen.
        Ganz lieben Dank dafür

        CodierknechtC 1 Reply Last reply
        0
        • J jprisum.de

          @codierknecht

          Wie gesagt habe ich das Script vor Jahren mal abgeschrieben und zum laufen gebracht (man war ich Stolz :-p) aber so wie du schon geschrieben hast und da gebe ich Dir recht, kann es keine S.... mehr lesen, Asche auf mein Haupt, ich bin nur Abtipper und leider kein Programmierer, freu mich dafür um so mehr, wenn sich Leute wir Ihr es mir dann versuchen beizubringen.
          Ganz lieben Dank dafür

          CodierknechtC Offline
          CodierknechtC Offline
          Codierknecht
          Developer Most Active
          wrote on last edited by
          #10

          @jprisum-de
          Gerne - Keine Ursache!

          Den eigentlichen Kardinalfehler hat dann derjenige erzeugt, der das Script seinerzeit zur Verfügung gestellt hat.
          Aber das Ding ist vermutlich auch steinalt.
          Ich bin ja selbst auch kein Experte in JS, meine mich aber erinnern zu können, dass JS früher mal wesentlich toleranter war.
          Dass es jetzt nicht mehr so tolerant ist, ist aber eher Vor- als Nachteil. In meiner Welt weist mich mein Compiler auf so'n Quatsch hin und compiliert gar nicht erst 😉

          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

          Proxmox 8.2.4 LXC|8 GB|Core i7-6700
          HmIP|ZigBee|Tasmota|Unifi + dies & das
          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

          OliverIOO 1 Reply Last reply
          0
          • CodierknechtC Codierknecht

            @jprisum-de
            Gerne - Keine Ursache!

            Den eigentlichen Kardinalfehler hat dann derjenige erzeugt, der das Script seinerzeit zur Verfügung gestellt hat.
            Aber das Ding ist vermutlich auch steinalt.
            Ich bin ja selbst auch kein Experte in JS, meine mich aber erinnern zu können, dass JS früher mal wesentlich toleranter war.
            Dass es jetzt nicht mehr so tolerant ist, ist aber eher Vor- als Nachteil. In meiner Welt weist mich mein Compiler auf so'n Quatsch hin und compiliert gar nicht erst 😉

            OliverIOO Offline
            OliverIOO Offline
            OliverIO
            wrote on last edited by
            #11

            @codierknecht sagte in Script funzt nicht mehr:

            In meiner Welt weist mich mein Compiler auf so'n Quatsch

            In dieser Welt auch, sogar in der iobroker IDE (hüstel).
            Diese kleine gewellte rote Linie unter array teilt dir sowas mit, wenn man mit der Maus drüber schwebt.

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

            CodierknechtC 1 Reply Last reply
            0
            • OliverIOO OliverIO

              @codierknecht sagte in Script funzt nicht mehr:

              In meiner Welt weist mich mein Compiler auf so'n Quatsch

              In dieser Welt auch, sogar in der iobroker IDE (hüstel).
              Diese kleine gewellte rote Linie unter array teilt dir sowas mit, wenn man mit der Maus drüber schwebt.

              CodierknechtC Offline
              CodierknechtC Offline
              Codierknecht
              Developer Most Active
              wrote on last edited by
              #12

              @oliverio
              Ja - soweit klar, aber es wird nix verhindert.
              Wäre möglicherweise ja nicht unpraktisch, wenn der Start eines solchen Scriptes einfach unterbunden würde.

              Gehört zwar jetzt nicht unbedingt hier hin, aber meine CI-Pipeline verhindert sogar den Build, wenn die statische Codeanalyse einen Pieps sagt: Unbenutzte oder nicht initialisierte Variablen, Naming-Conventions nicht eingehalten, Methoden zu lang etc. p.p.

              Ich versuche halt gerade, mich mit JS anzufreunden 😉

              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

              Proxmox 8.2.4 LXC|8 GB|Core i7-6700
              HmIP|ZigBee|Tasmota|Unifi + dies & das
              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

              HomoranH 1 Reply Last reply
              0
              • CodierknechtC Codierknecht

                @oliverio
                Ja - soweit klar, aber es wird nix verhindert.
                Wäre möglicherweise ja nicht unpraktisch, wenn der Start eines solchen Scriptes einfach unterbunden würde.

                Gehört zwar jetzt nicht unbedingt hier hin, aber meine CI-Pipeline verhindert sogar den Build, wenn die statische Codeanalyse einen Pieps sagt: Unbenutzte oder nicht initialisierte Variablen, Naming-Conventions nicht eingehalten, Methoden zu lang etc. p.p.

                Ich versuche halt gerade, mich mit JS anzufreunden 😉

                HomoranH Offline
                HomoranH Offline
                Homoran
                Global Moderator Administrators
                wrote on last edited by Homoran
                #13

                @codierknecht sagte in Script funzt nicht mehr:

                , aber es wird nix verhindert.

                dafür erscheint es direkt darunter mit Stellenangabe

                wobei mich Zeile 6922 schon irritiert

                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 -

                CodierknechtC 1 Reply Last reply
                0
                • HomoranH Homoran

                  @codierknecht sagte in Script funzt nicht mehr:

                  , aber es wird nix verhindert.

                  dafür erscheint es direkt darunter mit Stellenangabe

                  wobei mich Zeile 6922 schon irritiert

                  CodierknechtC Offline
                  CodierknechtC Offline
                  Codierknecht
                  Developer Most Active
                  wrote on last edited by
                  #14

                  @homoran sagte in Script funzt nicht mehr:

                  wobei mich Zeile 6922 schon irritiert

                  Dann bin ich ja wenigstens nicht alleine 😁
                  Und was hat er da an Zeile 7 zu meckern? Ist doch leer.

                  "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                  Proxmox 8.2.4 LXC|8 GB|Core i7-6700
                  HmIP|ZigBee|Tasmota|Unifi + dies & das
                  Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                  HomoranH 1 Reply Last reply
                  0
                  • CodierknechtC Codierknecht

                    @homoran sagte in Script funzt nicht mehr:

                    wobei mich Zeile 6922 schon irritiert

                    Dann bin ich ja wenigstens nicht alleine 😁
                    Und was hat er da an Zeile 7 zu meckern? Ist doch leer.

                    HomoranH Offline
                    HomoranH Offline
                    Homoran
                    Global Moderator Administrators
                    wrote on last edited by
                    #15

                    @codierknecht sagte in Script funzt nicht mehr:

                    was hat er da an Zeile 7 zu meckern?

                    das ist die Spalte der Zeile.malso das 7. Zeichen in 6299.

                    so hohe nicht vorhandenen Zeilen bekommt man z. B. über vorangestellte globale Skripte

                    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 -

                    CodierknechtC liv-in-skyL 2 Replies Last reply
                    0
                    • HomoranH Homoran

                      @codierknecht sagte in Script funzt nicht mehr:

                      was hat er da an Zeile 7 zu meckern?

                      das ist die Spalte der Zeile.malso das 7. Zeichen in 6299.

                      so hohe nicht vorhandenen Zeilen bekommt man z. B. über vorangestellte globale Skripte

                      CodierknechtC Offline
                      CodierknechtC Offline
                      Codierknecht
                      Developer Most Active
                      wrote on last edited by Codierknecht
                      #16

                      < hier stand quatsch >
                      Hatte mich vertan. Ich meinte mal 'ne Zeilennummer gelesen zu haben, die auf eine leere Zeile zeigte.

                      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                      Proxmox 8.2.4 LXC|8 GB|Core i7-6700
                      HmIP|ZigBee|Tasmota|Unifi + dies & das
                      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                      HomoranH 1 Reply Last reply
                      0
                      • HomoranH Homoran

                        @codierknecht sagte in Script funzt nicht mehr:

                        was hat er da an Zeile 7 zu meckern?

                        das ist die Spalte der Zeile.malso das 7. Zeichen in 6299.

                        so hohe nicht vorhandenen Zeilen bekommt man z. B. über vorangestellte globale Skripte

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        wrote on last edited by
                        #17

                        @homoran

                        oder wenn eine (geschweifte) klammer fehlt

                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                        1 Reply Last reply
                        0
                        • CodierknechtC Codierknecht

                          < hier stand quatsch >
                          Hatte mich vertan. Ich meinte mal 'ne Zeilennummer gelesen zu haben, die auf eine leere Zeile zeigte.

                          HomoranH Offline
                          HomoranH Offline
                          Homoran
                          Global Moderator Administrators
                          wrote on last edited by
                          #18

                          @codierknecht sagte in Script funzt nicht mehr:

                          Ich meinte das hier:

                          achso!
                          wenn die hohe Zeilenzahl wegen eines globalen Skripts ist, ist die Zeile 7 in diesem globalen Skript zu suchen

                          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 -

                          CodierknechtC 2 Replies Last reply
                          0
                          • HomoranH Homoran

                            @codierknecht sagte in Script funzt nicht mehr:

                            Ich meinte das hier:

                            achso!
                            wenn die hohe Zeilenzahl wegen eines globalen Skripts ist, ist die Zeile 7 in diesem globalen Skript zu suchen

                            CodierknechtC Offline
                            CodierknechtC Offline
                            Codierknecht
                            Developer Most Active
                            wrote on last edited by
                            #19

                            @homoran
                            Mein Fehler. Siehe meinen geänderten Post

                            "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                            Proxmox 8.2.4 LXC|8 GB|Core i7-6700
                            HmIP|ZigBee|Tasmota|Unifi + dies & das
                            Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                            1 Reply Last reply
                            1
                            • HomoranH Homoran

                              @codierknecht sagte in Script funzt nicht mehr:

                              Ich meinte das hier:

                              achso!
                              wenn die hohe Zeilenzahl wegen eines globalen Skripts ist, ist die Zeile 7 in diesem globalen Skript zu suchen

                              CodierknechtC Offline
                              CodierknechtC Offline
                              Codierknecht
                              Developer Most Active
                              wrote on last edited by
                              #20

                              @homoran
                              Da ich ja selbst noch dabei bin, mich mit JS anzufreunden, würde ich das Beispiel gerne mal nehmen und versuchen, das umzubauen.
                              Dazu mache ich aber einen neuen Thread auf.
                              Welcher das ist, folgt dann an dieser Stelle später.

                              Spricht etwas dagegen?

                              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                              Proxmox 8.2.4 LXC|8 GB|Core i7-6700
                              HmIP|ZigBee|Tasmota|Unifi + dies & das
                              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                              HomoranH 1 Reply Last reply
                              0
                              • CodierknechtC Codierknecht

                                @homoran
                                Da ich ja selbst noch dabei bin, mich mit JS anzufreunden, würde ich das Beispiel gerne mal nehmen und versuchen, das umzubauen.
                                Dazu mache ich aber einen neuen Thread auf.
                                Welcher das ist, folgt dann an dieser Stelle später.

                                Spricht etwas dagegen?

                                HomoranH Offline
                                HomoranH Offline
                                Homoran
                                Global Moderator Administrators
                                wrote on last edited by
                                #21

                                @codierknecht sagte in Script funzt nicht mehr:

                                Spricht etwas dagegen?

                                warum sollte ich dich bremsen

                                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 -

                                CodierknechtC 1 Reply Last reply
                                0
                                • HomoranH Homoran

                                  @codierknecht sagte in Script funzt nicht mehr:

                                  Spricht etwas dagegen?

                                  warum sollte ich dich bremsen

                                  CodierknechtC Offline
                                  CodierknechtC Offline
                                  Codierknecht
                                  Developer Most Active
                                  wrote on last edited by
                                  #22

                                  @homoran
                                  Du hast es nicht anders gewollt: https://forum.iobroker.net/topic/60034/learning-js-ein-erster-versuch

                                  "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                  Proxmox 8.2.4 LXC|8 GB|Core i7-6700
                                  HmIP|ZigBee|Tasmota|Unifi + dies & das
                                  Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                  1 Reply Last reply
                                  1
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes


                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  114

                                  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