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. Funktion mit unterschiedlicher Anzahl an paramtern

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

Funktion mit unterschiedlicher Anzahl an paramtern

Geplant Angeheftet Gesperrt Verschoben JavaScript
13 Beiträge 4 Kommentatoren 542 Aufrufe 3 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.
  • Ben1983B Ben1983

    @martinp also ich habe schon einmal so etwas realisiert:

    function (message,username,visuLog = false, SendInstanz = 0){
    ...
    }
    

    das geht, aber wie kann ich jetzt bspw. message und SendInstanz übergeben und und visulog weg lassen?
    Also man bekommt ja beim Aufruf keine Auswahl, was man übergeben will.
    verstehst Du, was ich meine?

    T Nicht stören
    T Nicht stören
    ticaki
    schrieb am zuletzt editiert von ticaki
    #4

    @ben1983

    ('bla', undefined, 1)

    Alternative geht es natürlich das du am anfang der funktion die parameter sortierst z.B.:

    async setActivePage(_page?: Page | boolean, _notSleep?: boolean): Promise<void> {
            if (_page === undefined) {
                return;
            }
            let page = this._activePage;
            let sleep = false;
            if (typeof _page === 'boolean') {
                sleep = !_page;
            } else {
                page = _page;
                sleep = _notSleep ?? false;
            }
    

    ich sehe da gerade das mal eine der beiden vars umbennen muß... :D

    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

    Spenden

    Ben1983B 1 Antwort Letzte Antwort
    0
    • T ticaki

      @ben1983

      ('bla', undefined, 1)

      Alternative geht es natürlich das du am anfang der funktion die parameter sortierst z.B.:

      async setActivePage(_page?: Page | boolean, _notSleep?: boolean): Promise<void> {
              if (_page === undefined) {
                  return;
              }
              let page = this._activePage;
              let sleep = false;
              if (typeof _page === 'boolean') {
                  sleep = !_page;
              } else {
                  page = _page;
                  sleep = _notSleep ?? false;
              }
      

      ich sehe da gerade das mal eine der beiden vars umbennen muß... :D

      Ben1983B Offline
      Ben1983B Offline
      Ben1983
      schrieb am zuletzt editiert von Ben1983
      #5

      @ticaki sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

      @ben1983

      ('bla', undefined, 1)

      OK, aber ich müsste dann trotzdem immer noch einen Aufruf mit 3 Parametern machen, richtig?
      Also so schön mit 2, oder 3 geht es nicht.

      Oder man muss ein Objekt übergeben. Aber da kann ich wieder keine Vorbelegung machen im sinne von:

      Options ={a:1, b:false}
      

      denn dann, wird beim aufrufe genau diese struktur erwartet.

      Wenn ich es frei lasse... ich habe mal versucht die Parameter zu beschreiben, aber irgendwie gehts nicht.

      const TestXY = {
          /**
           * @param Message message to send
           * @param Username 
           * @param Options visulog-Sendinstanz
           */
          alles: function (Message,Username,Options){
              if(!Options.SendInstanz)
              log(Message);
              log(Username);
              log(JSON.stringify(Options));
          }
      }
      
      

      Edit: geht doch

      T MartinPM 2 Antworten Letzte Antwort
      0
      • Ben1983B Ben1983

        @ticaki sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

        @ben1983

        ('bla', undefined, 1)

        OK, aber ich müsste dann trotzdem immer noch einen Aufruf mit 3 Parametern machen, richtig?
        Also so schön mit 2, oder 3 geht es nicht.

        Oder man muss ein Objekt übergeben. Aber da kann ich wieder keine Vorbelegung machen im sinne von:

        Options ={a:1, b:false}
        

        denn dann, wird beim aufrufe genau diese struktur erwartet.

        Wenn ich es frei lasse... ich habe mal versucht die Parameter zu beschreiben, aber irgendwie gehts nicht.

        const TestXY = {
            /**
             * @param Message message to send
             * @param Username 
             * @param Options visulog-Sendinstanz
             */
            alles: function (Message,Username,Options){
                if(!Options.SendInstanz)
                log(Message);
                log(Username);
                log(JSON.stringify(Options));
            }
        }
        
        

        Edit: geht doch

        T Nicht stören
        T Nicht stören
        ticaki
        schrieb am zuletzt editiert von
        #6

        @ben1983
        hab editiert gehabt :)

        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

        Spenden

        1 Antwort Letzte Antwort
        0
        • Ben1983B Ben1983

          Hallo, wie kann man im JavaScript Adaptrer Funktionen mit unterschiedlicher Anzahl an Parametern definieren?
          Also bsp., wenn man Log aufruft:

          39b3271f-7501-47eb-9212-9b3c8369e100-image.png
          Hier hat man ja links unter die Ansicht, dass es zweit unterschiedliche Aufrufmöglichkeiten gibt.

          Kann ich es irgendwie hinbekommen, dass ich mit

          function myTestfunction(a,b){
          }
          

          einmal so aufrufen kann

          myTestfunction(ersterParameter);
          

          und einmal so

          myTestfunction(ersterParameter, zweiterParameter);
          
          haus-automatisierungH Online
          haus-automatisierungH Online
          haus-automatisierung
          Developer Most Active
          schrieb am zuletzt editiert von
          #7

          @ben1983 sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

          Hier hat man ja links unter die Ansicht, dass es zweit unterschiedliche Aufrufmöglichkeiten gibt.

          Das gibt dir die Definition so vor. Die aufgerufene Funktion ist jeweils genau die gleiche. Man kann in JavaScript keine Funktionen überladen und mit unterschiedlicher Anzahl Parametern mehrfach definieren (wie das z.B. in anderen Sprachen geht).

          Du kannst einfach Parameter beim Aufruf weglassen. Ob und wie die Funktion damit klar kommt, musst Du in der Programmierung festlegen. Die fehlenden Parameter sind dann halt undefined.

          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
          📚 Meine inoffizielle ioBroker Dokumentation

          Ben1983B 1 Antwort Letzte Antwort
          0
          • Ben1983B Ben1983

            @ticaki sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

            @ben1983

            ('bla', undefined, 1)

            OK, aber ich müsste dann trotzdem immer noch einen Aufruf mit 3 Parametern machen, richtig?
            Also so schön mit 2, oder 3 geht es nicht.

            Oder man muss ein Objekt übergeben. Aber da kann ich wieder keine Vorbelegung machen im sinne von:

            Options ={a:1, b:false}
            

            denn dann, wird beim aufrufe genau diese struktur erwartet.

            Wenn ich es frei lasse... ich habe mal versucht die Parameter zu beschreiben, aber irgendwie gehts nicht.

            const TestXY = {
                /**
                 * @param Message message to send
                 * @param Username 
                 * @param Options visulog-Sendinstanz
                 */
                alles: function (Message,Username,Options){
                    if(!Options.SendInstanz)
                    log(Message);
                    log(Username);
                    log(JSON.stringify(Options));
                }
            }
            
            

            Edit: geht doch

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

            @ben1983 sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

            Oder man muss ein Objekt übergeben. Aber da kann ich wieder keine Vorbelegung machen im sinne von:

            Kann man ja durchaus trotzdem machen

            FuncWithObjecf(obj1){
            // Parameter vorbelegen
            par1 = "BLA";
            par2= 1;
            ...
            parN="Letzter";
            // vorbelegungen aus Objekt überschreiben (soweit vorhanden)

            FuncWithPar(par1, par2, ..... parN);
            }

            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
            • haus-automatisierungH haus-automatisierung

              @ben1983 sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

              Hier hat man ja links unter die Ansicht, dass es zweit unterschiedliche Aufrufmöglichkeiten gibt.

              Das gibt dir die Definition so vor. Die aufgerufene Funktion ist jeweils genau die gleiche. Man kann in JavaScript keine Funktionen überladen und mit unterschiedlicher Anzahl Parametern mehrfach definieren (wie das z.B. in anderen Sprachen geht).

              Du kannst einfach Parameter beim Aufruf weglassen. Ob und wie die Funktion damit klar kommt, musst Du in der Programmierung festlegen. Die fehlenden Parameter sind dann halt undefined.

              Ben1983B Offline
              Ben1983B Offline
              Ben1983
              schrieb am zuletzt editiert von
              #9

              @haus-automatisierung OK.

              gehen wir mal abstrakt davon aus, dass es diese funktion ist:

              function Testfunction(a,b,c,d){}
              

              und der Aufruf:

              Testfunction(1,3);
              

              woher weis ich denn nun, wohin zugewiesen wird?
              also es könnte ja sein, dass die 1 zu c und die 3 zu d zugewiesen werden soll.
              Wie sollte das passieren?

              T haus-automatisierungH 2 Antworten Letzte Antwort
              0
              • Ben1983B Ben1983

                @haus-automatisierung OK.

                gehen wir mal abstrakt davon aus, dass es diese funktion ist:

                function Testfunction(a,b,c,d){}
                

                und der Aufruf:

                Testfunction(1,3);
                

                woher weis ich denn nun, wohin zugewiesen wird?
                also es könnte ja sein, dass die 1 zu c und die 3 zu d zugewiesen werden soll.
                Wie sollte das passieren?

                T Nicht stören
                T Nicht stören
                ticaki
                schrieb am zuletzt editiert von
                #10

                @ben1983

                Wie haus geschrieben hat - selber machen. Woher soll bitte Javascript wissen wo es hinsoll? Entweder wie in meinem Bespiel oben, anhand von typen/wertebereichen bestimmen was wo hinsoll oder halt:

                function x(b,c){
                  z(undefined, b, c)
                }
                
                function z (a,b,c) {}
                

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                Ben1983B 1 Antwort Letzte Antwort
                1
                • T ticaki

                  @ben1983

                  Wie haus geschrieben hat - selber machen. Woher soll bitte Javascript wissen wo es hinsoll? Entweder wie in meinem Bespiel oben, anhand von typen/wertebereichen bestimmen was wo hinsoll oder halt:

                  function x(b,c){
                    z(undefined, b, c)
                  }
                  
                  function z (a,b,c) {}
                  
                  Ben1983B Offline
                  Ben1983B Offline
                  Ben1983
                  schrieb am zuletzt editiert von
                  #11

                  @ticaki OK, dann mache ich es mit einem Objekt deklariert als "Options".
                  Danke

                  1 Antwort Letzte Antwort
                  0
                  • Ben1983B Ben1983

                    @haus-automatisierung OK.

                    gehen wir mal abstrakt davon aus, dass es diese funktion ist:

                    function Testfunction(a,b,c,d){}
                    

                    und der Aufruf:

                    Testfunction(1,3);
                    

                    woher weis ich denn nun, wohin zugewiesen wird?
                    also es könnte ja sein, dass die 1 zu c und die 3 zu d zugewiesen werden soll.
                    Wie sollte das passieren?

                    haus-automatisierungH Online
                    haus-automatisierungH Online
                    haus-automatisierung
                    Developer Most Active
                    schrieb am zuletzt editiert von haus-automatisierung
                    #12

                    @ben1983 sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

                    woher weis ich denn nun, wohin zugewiesen wird?

                    Du kannst nur hinten etwas weglassen. Also in dem Beispiel wird a = 1 und b = 3. c und d ist dann undefined.

                    Daher solltest Du die Reihenfolge der Parameter so definieren, dass hinten die optionalen Parameter stehen. Wenn das sehr viele werden, ist es natürlich sinnvoller ein Objekt zu übergeben.

                    Am besten schaust Du dir mal an wie andere Projekte das machen oder entwickelst auf GitHub mit - da lernt man am meisten.

                    🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                    🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                    📚 Meine inoffizielle ioBroker Dokumentation

                    Ben1983B 1 Antwort Letzte Antwort
                    0
                    • haus-automatisierungH haus-automatisierung

                      @ben1983 sagte in Funktion mit unterschiedlicher Anzahl an paramtern:

                      woher weis ich denn nun, wohin zugewiesen wird?

                      Du kannst nur hinten etwas weglassen. Also in dem Beispiel wird a = 1 und b = 3. c und d ist dann undefined.

                      Daher solltest Du die Reihenfolge der Parameter so definieren, dass hinten die optionalen Parameter stehen. Wenn das sehr viele werden, ist es natürlich sinnvoller ein Objekt zu übergeben.

                      Am besten schaust Du dir mal an wie andere Projekte das machen oder entwickelst auf GitHub mit - da lernt man am meisten.

                      Ben1983B Offline
                      Ben1983B Offline
                      Ben1983
                      schrieb am zuletzt editiert von Ben1983
                      #13

                      @haus-automatisierung OK, danke.

                      Nur folgendes:

                      Wenn ich Bspw. so eine Funktion deklariere:

                      const SendTelegram = {
                          /**
                           * @param Message message to send
                           * @param Options Username, Visulog, SendInstanz
                           */
                          alles: function (Message,Options){
                              ....... //code
                          }
                      }
                      

                      Die liegt in einem Globalen Skript, ist also überall verfügbar.

                      Wenn ich sie innerhalb des Skripts aufrufe, dann wird mir das angezeigt:
                      3a62fcb8-1ebd-4e11-95a4-e1c30c394e2b-image.png

                      in einem nicht globalen Skript, allerdings:
                      f6aecbff-3a56-47af-8e40-b4bb143be1ed-image.png

                      Ich weiß nun, was die options sind, aber warum wird das nicht angezeigt?

                      EDIT: !!!! Es geht doch.... nachdem die Fenster einmal geschlossen waren und wieder geöffnet wurde, wird es angezeigt.

                      OK, ich gebs aus... fenster erneut geschlossen und geöffnet und es wird schon wieder nicht angezeigt

                      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

                      782

                      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