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

  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Problem mit Variablen Vererbung in Javascript Klasse

NEWS

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

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

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.3k

Problem mit Variablen Vererbung in Javascript Klasse

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
2 Beiträge 2 Kommentatoren 370 Aufrufe
  • Ä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.
  • P Offline
    P Offline
    Psens
    schrieb am zuletzt editiert von
    #1

    Hallo,

    ich möchte mir klassen anlegen die wie nachfolgend, z.B. die Auswertung und Steuerung von Schaltsteckdosen mit Leistungsmessung übernehmen,

    mein Problem ist das die Variable this.leistung und this.name in dem Unterobjekt "on" keine Gültigkeit haben, wie kann ich diese übergeben, bzw. auf diese aus der on-Funktion zugreifen?

    class EnergieMesser{
        constructor(name, datenpunkt, leistung){
            this.name = name;
            this.datenpunkt = datenpunkt;
            this.leistung = leistung;
            createState(this.leistung, 0.0);
            log(this.name);
            log(this.leistung);
            on({id: this.datenpunkt, change:"ne"}, function (obj){
                var dblValAlt = obj.oldState.val;
                var dblValNeu = obj.newState.val;
                var intTimeAlt = obj.oldState.ts;
                var intTimeNeu = obj.newState.ts;
                var dblFaktor = 3600 / ((intTimeNeu - intTimeAlt)/1000);
                var dblLeistung = (dblValNeu - dblValAlt) * dblFaktor;
                log(this.name + ": " + dblLeistung.toFixed(3) + " Wh");
                setState(this.leistung, dblLeistung);
            });
        }
    }
    

    Schon mal vielen Dank für eure Hilfe.

    Gruß Dominic

    1 Antwort Letzte Antwort
    0
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #2

      Der übliche Trick ist vor dem on eine variable zu definieren die einen verweis auf "this" hat. Diese hat dann auch innerhalb der Funktion (weil für die Funktion ist Sie quasi "global") gültig.

      Übliche Namen sind "self" oder "that".

      also:

      var self = this;
      on('myevent', function() {
        self.whatever();
      });
      

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      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

      342

      Online

      32.4k

      Benutzer

      81.4k

      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