JavaScript - Arbeiten mit Objekten: Unterschied zwischen den Versionen
| Zeile 90: | Zeile 90: | ||
</pre> | </pre> | ||
Assuming obj is your JSON as above, this should give you something like (not tested): | Assuming obj is your JSON as above, this should give you something like (not tested): | ||
| − | < | + | <pre> |
depth: 0: obj1 | depth: 0: obj1 | ||
depth: 1: obj1.1 | depth: 1: obj1.1 | ||
Version vom 5. Dezember 2014, 15:17 Uhr
Links
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Introduction_to_Object-Oriented_JavaScript
Klassen und Objekte in JavaScript
Objekte statt Arrays
JavaScript Objekt und JavaScript Array
Im Prinzip ist ein Array ein spezielles JavaScript Objekt. Da die Arbeit mit Arrays aber wesentlich unkomfortabler ist wie z.B. in PHP ist es oft besser statt einem Array ein Objekt zu nutzen. Gerade wenn man mit mehrdimensionalen Arrays arbeiten will stößt man mit JavaScript schnell an Grenzen.
Objekt statt mehrdimensionales Array
Quelle: http://stackoverflow.com/questions/4329092/multi-dimensional-associative-arrays-in-javascript (Zugriff 07-2013)
I wish to store the data in a grid (maybe as an array) looping all the records like this:
apple orange banana melon fred 2 4 7 - mary - 10 - - sarah - - - 5
var obj = {};
obj['fred'] = {};
if('fred' in obj ){ } // can check for the presence of 'fred'
if(obj.fred) { } // also checks for presence of 'fred'
if(obj['fred']) { } // also checks for presence of 'fred'
// The following statements would all work
obj['fred']['apples'] = 1;
obj.fred.apples = 1;
obj['fred'].apples = 1;
// or build or initialize the structure outright
var obj = { fred: { apples: 1, oranges: 2 }, alice: { lemons: 1 } };
If you're looking over values, you might have something that looks like this:
var people = ['fred', 'alice'];
var fruit = ['apples', 'lemons'];
var grid = {};
for(var i = 0; i < people.length; i++){
var name = people[i];
if(name in grid == false){
grid[name] = {}; // must initialize the sub-object, otherwise will get 'undefined' errors
}
for(var j = 0; j < fruit.length; j++){
var fruitName = fruit[j];
grid[name][fruitName] = 0;
}
}
Schleifen mit Objekten
Beispiel aus Stackoverflow:
{
"obj1" : {
"obj1.1" : "test",
"obj1.2" : {
"obj1.1.1" : true,
"obj1.1.2" : "test2",
"obj1.1.3" : {
... // etc
}
}
}
}
function dig( blob, depth ) {
var depth = depth || 0; // start at level zero
for( var item in blob ) {
console.log( 'depth: ' + depth + ': ' + item); // do something real here
if( typeof blob[item] === 'object' ) {
dig( blob[item], ++depth ); // descend
} else { // simple value, leaf
console.log( ' => ' + blob[item] ); // do something real here
}
}
}
console.log( dig( obj ) );
Assuming obj is your JSON as above, this should give you something like (not tested):
depth: 0: obj1 depth: 1: obj1.1 => test depth: 1: obj1.2 // etc.
JavaScript - Namespace
Teste ob Objekt vorhanden, wenn nicht erstelle Objekt. Alle Funktionen und Eigenschaften sind in diesem Objekt definiert. Dadurch befinden wir uns in einme einheitlichen Namensraum.
// global namespace
var MYAPP = MYAPP || {};