<code>function returnfunc (propertyName) { return function (obj) { //-----这行定义并返回了一个闭包,也被称之为一个匿名函数 return obj[propertyName]; //这里用方括号法访问属性,因为属性是变量(returnfunc()函数的参数) }; } var savefunc = returnfunc("name"); //调用returnfunc() var result = savefunc({name:"Picasso"});//调用savefunc() alert(result); //返回字符串“Picasso” </code>
Entschuldigung, Name: „Picasso“
in savefunc({name: „Picasso“})<code>function returnfunc (propertyName) { return function (obj) { //-----这行定义并返回了一个闭包,也被称之为一个匿名函数 return obj[propertyName]; //这里用方括号法访问属性,因为属性是变量(returnfunc()函数的参数) }; } var savefunc = returnfunc("name"); //调用returnfunc() var result = savefunc({name:"Picasso"});//调用savefunc() alert(result); //返回字符串“Picasso” </code>
Entschuldigung, Name: „Picasso“
in savefunc({name: „Picasso“})
Die mit Punkten und [] sind beide Möglichkeiten, die Eigenschaften von Objekten auszudrücken, aber letzteres enthält Zeichenfolgen. Beachten Sie, dass es sich um Zeichenfolgen handelt.
Zuerst wird nach der Ausführung eine Variable generiert var propertyName = "name";
Dann:
<code>var savrfunc = function(obj){ return obj[propertyName]; } </code>
Dann wird die obige Funktion ausgeführt und der Rückgabewert wird an das Ergebnis zurückgegeben. Der Ausführungseffekt in
entspricht:
<code>var obj = {name:"Picasso"}; return obj[propertyName]//上面 已经有这个变了 值是name ;所以就是返回了 obj.name ,相当于把 Picasso给返回出去了。 </code>
Gleiche Funktion wie ., aber andere Verwendung
<code>var text ='prop'; var obj = { prop:123 }; obj.prop//123 obj.text//undefined obj[text]//123</code>
propertyName ist der Eigenschaftsname, person[propertyName] ist person['name']
return obj[propertyName]; //这里用方括号法访问属性,因为属性是变量(returnfunc()函数的请输入代码参数)
Das steht alles in Ihren Kommentaren.
Es gibt zwei Möglichkeiten, auf die Eigenschaften eines Objekts zuzugreifen:
obj.attr-Format, einfach zu schreiben
obj[attr], der Attributname kann in Form einer Variablen
und [] können beide auf das Objekt
zugreifen
Quelle: „JavaScript Standard Reference Tutorial (alpha)“, von Ruan Yifeng