NEWS
[GELÖST] Skript gibt [objekt Objekt] aus
- 
					
					
					
					
 Okay wollte es nur wissen nicht das ich da was falsches gelernt hab  
- 
					
					
					
					
 @codierknecht sagte in Skript gibt [objekt Objekt] aus: Mach halt ein var draus, wenn Du es brauchst. var braucht man nie  immer nur let und const. immer nur let und const.Ansonsten kann common.namenatürlich auch ein Objekt sein, wenn es in mehrere Sprachen übersetzt ist. Also z.B.common.name.dewäre dann die Deutsche Übersetzung.
- 
					
					
					
					
 also sollte ich es so versuchen? cacheSelectorState.each(function (id, i) { const obj = await getObjectAsync(id); if (obj && obj.common) { var oName = obj.common.name; var státus = getState(id).val; } if (status) { ++anzahlUpdateAn; textUpdateAn.push(Oname); }
- 
					
					
					
					
 wie jetzt man bruacht nie var? 
- 
					
					
					
					
 @fischi87 sagte in Skript gibt [objekt Objekt] aus: also sollte ich es so versuchen? Bitte nicht  Der Scope von Der Scope vonstatusist absolut blöde so.cacheSelectorState.each(function (id, i) { let anzahlUpdateAn = 0; const obj = await getObjectAsync(id); if (obj && obj.common) { const oName = typeof obj.common.name === 'object' ? obj.common.name.de : obj.common.name; if (getState(id).val) { anzahlUpdateAn++; textUpdateAn.push(oName); } } )};Und achte darauf, Variablen RICHTIG wieder zu verwenden. Du schreibst oNameund untenOname. Das sind zwei komplett verschiedene Dinge. Genau wiestátus
- 
					
					
					
					
 @fischi87 sagte in Skript gibt [objekt Objekt] aus: wie jetzt man bruacht nie var? Na einfach NIE var ...schreiben. Siehst Du ja an deinem Code. Du deklarierst innerhalb desif ...eine Variable (z.B.oName) und möchtest diese außerhalb wieder verwenden. Das ist kein schöner Code und sollte man nie so machen.Brauchst Du diese außerhalb, musst diese auch vorher außerhalb mit letdeklarieren (falls diese geändert werden sollen). Ansonsten mitconstarbeiten.Google: JavaScript variable scopes https://www.w3schools.com/js/js_scope.asp 
- 
					
					
					
					
 Und achte darauf, Variablen RICHTIG wieder zu verwenden Ähämmm ... räusper textUpdateAn.push(oName); 
- 
					
					
					
					
 @codierknecht sagte in Skript gibt [objekt Objekt] aus: Ähämmm ... räusper Danke, im Forum programmieren ist so eine Sache  
- 
					
					
					
					
 @haus-automatisierung 
 Nur interessehalber:
 Wie verwendest Du den Inkrement-Operator in einem solchen Fall:++anzahlUpdateAn;Vor oder nach der Variablen? @fischi87 
 Es ist halt ein himmelweiter Unterschied, ob man das so
 Schlechtes Beispiel. Siehe unten.for (var i = 0; i < 100; i++)oder so for (var i = 0; i < 100; ++i)verwendet. 
- 
					
					
					
					
 @codierknecht sagte in Skript gibt [objekt Objekt] aus: Vor oder nach der Variablen? Wenn der alleine in einer Zeile steht ist das völlig egal. Dann aber meistens hinter der Variable. Ist ja nur entscheidend, wenn man das direkt als Parameter übergibt o.ä. @codierknecht sagte in Skript gibt [objekt Objekt] aus: @fischi87 
 Es ist halt ein himmelweiter Unterschied, ob man das soIn dem Fall nicht. Beide gehen von 0 bis 99. In einer for-Schleife mache ich es immer dahinter. Macht in deinem Beispiel aber auch keinen Unterschied bei der Schleife (weil es ja alleine steht). Hier wäre es ein Unterschied: let i = 0; do { console.log(i); } while (++i < 100); // 0 bis 99 let i = 0; do { console.log(i); } while (i++ < 100); // 0 bis 100
- 
					
					
					
					
 @haus-automatisierung 
 Asche auf mein Haupt. Schlechtes Beispiel 
- 
					
					
					
					
 @codierknecht sagte: getObject() liest aber asynchron. getObject(id) liest synchron, wenn keine Callback-Funktion übergeben wird. 
- 
					
					
					
					
 @paul53 
 Ich sag' ja: An dem synchron/synchron Kram verzweifle ich noch 
- 
					
					
					
					
 @codierknecht sagte in Skript gibt [objekt Objekt] aus: An dem synchron/synchron Kram verzweifle ich noch Ich verwende einfach immer die ...Async-Funktionen. Dann kann ich sicher sein, dass ich ein Promise zurückbekomme und kann damit dann halt mitawaitoder.then()weitermachen... Callbacks sind ja irgendwie retro und führen nur zu stark verschachteltem Code.
- 
					
					
					
					
 @haus-automatisierung sagte in Skript gibt [objekt Objekt] aus: Ich verwende einfach immer die ...Async-Funktionen Ich ja mittlerweile auch. Was aber auch daran liegen mag, dass ich das ganze Konzept noch immer nicht verinnerlicht habe. 
 Ich komme halt aus der Windows-Welt. Und da muss man Klimmzüge machen, um etwas asynchron hinzukriegen und nicht, um etwas synchron ablaufen zu lassen.
- 
					
					
					
					
 also müsste es so laufen wie im ersten post? jetzt bin ich verwirrt! 
- 
					
					
					
					
 @fischi87 sagte also müsste es so laufen wie im ersten post? Nicht ganz (Zeilen 50, 51) var obj = getObject(id); var name = getObject(id).common;Richtig: var name = getObject(id).common.name; if(typeof name == 'object') name = name.de;
- 
					
					
					
					
 @fischi87 sagte in Skript gibt [objekt Objekt] aus: also müsste es so laufen wie im ersten post? War wohl etwas viel Offtopic hier, aber fehlt Dir hier? https://forum.iobroker.net/topic/72999/skript-gibt-objekt-objekt-aus/17 
- 
					
					
					
					
 Sind denn da die Fehlermeldung bei .push und .sort auch behoben oder liegt die dann an einem anderen fehler? Danke dir erstmal. Ich glaube die Antwort auf die Frage nach dem „wie ist es richtig“ bzw „wie ist es am korrektesten“ wird man wohl nie beantworten können? 
- 
					
					
					
					
 @fischi87 
 Zur Überschrift: Zeile 68if (logging) log("Text: " + textUpdateAn);zeigt "Text: [objekt Objekt]", da textUpdateAnein Array enthält. Entwederif (logging) log("Text: " + JSON.stringify(textUpdateAn));oder if (logging) log(textUpdateAn);@fischi87 sagte in Skript gibt [objekt Objekt] aus: Sind denn da die Fehlermeldung bei .push und .sort auch behoben Ich sehe im ersten Post keinen Grund, weshalb es nicht funktionieren sollte. EDIT: Durch falsch gewählte Variablenbezeichner ( textUpdateAn) kann man sich auch selbst verwirren.
 
		
	 
		
	 
			
		 
			
		 
			
		