diff options
Diffstat (limited to 'files/zh-tw/web/javascript/reference/statements/for...in/index.html')
-rw-r--r-- | files/zh-tw/web/javascript/reference/statements/for...in/index.html | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/files/zh-tw/web/javascript/reference/statements/for...in/index.html b/files/zh-tw/web/javascript/reference/statements/for...in/index.html new file mode 100644 index 0000000000..8877c28d79 --- /dev/null +++ b/files/zh-tw/web/javascript/reference/statements/for...in/index.html @@ -0,0 +1,116 @@ +--- +title: for...in +slug: Web/JavaScript/Reference/Statements/for...in +translation_of: Web/JavaScript/Reference/Statements/for...in +--- +<p>{{jsSidebar("Statements")}}</p> + +<h2 id="Summary" name="Summary">Summary</h2> + +<p>迭代物件的可列舉屬性。對每個相異屬性,執行陳述式。</p> + +<table class="standard-table"> + <thead> + <tr> + <th colspan="2">Statement</th> + </tr> + </thead> + <tbody> + <tr> + <td>Implemented in:</td> + <td>JavaScript 1.0</td> + </tr> + <tr> + <td>ECMA Version:</td> + <td>ECMA-262</td> + </tr> + </tbody> +</table> + +<h2 id="Syntax" name="Syntax">語法</h2> + +<pre class="syntaxbox">for (<var>變數</var> in <var>物件</var>) {<em>...</em> +}</pre> + +<h3 id="Parameters" name="Parameters">參數</h3> + +<dl> + <dt><code>變數</code></dt> + <dd>A different property name is assigned to <em>variable</em> on each iteration.</dd> + <dt><code>物件</code></dt> + <dd>Object whose enumerable properties are iterated.</dd> +</dl> + +<h2 id="Description" name="Description">Description</h2> + +<p><code>for...in</code> 迴圈只迭代可列舉屬性。由內建建構式(如:Array、Object) 製造的物件,從 <code>Object.prototype</code> 和 <code>String.prototype</code> 繼承了不可列舉屬性,如: <code><a href="/en-US/docs/JavaScript/Reference/Global_Objects/String">String</a></code>的<code><a href="/en-US/docs/JavaScript/Reference/Global_Objects/String/indexOf">indexOf</a></code> 方法,或 <code><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object">Object</a></code>的 <code><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/toString">toString</a></code> 方法。 迴圈將迭代全部可列舉屬性,包括了物件自身的和物件繼承自它的建構式之原型的可列舉屬性。(原型鏈上較接近物件的屬性覆蓋原型的屬性)</p> + +<p>A <code>for...in</code> loop iterates over the properties of an object in an arbitrary order (see the <a href="/en-US/docs/JavaScript/Reference/Operators/delete#Cross-browser_issues">delete operator</a> for more on why one cannot depend on the seeming orderliness of iteration, at least in a cross-browser setting). If a property is modified in one iteration and then visited at a later time, its value in the loop is its value at that later time. A property that is deleted before it has been visited will not be visited later. Properties added to the object over which iteration is occurring may either be visited or omitted from iteration. In general it is best not to add, modify or remove properties from the object during iteration, other than the property currently being visited. There is no guarantee whether or not an added property will be visited, whether a modified property (other than the current one) will be visited before or after it is modified, or whether a deleted property will be visited before it is deleted.</p> + +<div class="note" id="hasOwnPropertyNote"> +<p>If you only want to consider properties attached to the object itself, and not its prototypes, use <a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/getOwnPropertyNames">getOwnPropertyNames</a> or perform a <a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/hasOwnProperty">hasOwnProperty</a> check (<a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/propertyIsEnumerable">propertyIsEnumerable</a> can also be used). Alternatively, if you know there won't be any outside code interference, you can extend built-in prototypes with a check method.</p> +</div> + +<div class="note" id="arrayNote"> +<p><strong><code>for..in</code> 不應該用來迭代一個索引順序很重要的<a href="/en-US/docs/JavaScript/Reference/Global_Objects/Array">陣列</a>。</strong> 陣列索引只是以整數命名的可列舉屬性,其他方面等同於一般物件屬性。 無法擔保 <code>for...in</code> 以特定順序傳回索引,並且它將傳回全部可列舉屬性,包括非整數名的,以及繼承而來的可列舉屬性。</p> + +<p>因為迭代的順序依賴於 JavaScript 引擎的實作,在不同引擎下,迭代一個陣列可能不是以一個一致的順序存取陣列元素。因此,當你迭代陣列,且該陣列的存取順序很重要時,最好是使用以數值索引的 <a href="/en-US/docs/JavaScript/Reference/Statements/for">for</a> 迴圈 (或 <a href="/en-US/docs/JavaScript/Reference/Global_Objects/Array/forEach">Array.forEach</a> 或非標準 <code><a href="/en-US/docs/JavaScript/Reference/Statements/for...of">for...of</a></code> 迴圈)。</p> +</div> + +<h2 id="Example" name="Example">Examples</h2> + +<p>The following function takes as its arguments an object and the object's name. It then iterates over all the object's enumerable properties and returns a string of the property names and their values.</p> + +<pre class="brush: js">var o = {a:1, b:2, c:3}; + +function show_props(obj, objName) { + var result = ""; + + for (var prop in obj) { + result += objName + "." + prop + " = " + obj[prop] + "\n"; + } + + return result; +} + +alert(show_props(o, "o")); /* alerts (in different lines): o.a = 1 o.b = 2 o.c = 3 */ +</pre> + +<p>The following function illustrates the use of hasOwnProperty: the inherited properties are not displayed.</p> + +<pre class="brush: js">var triangle = {a:1, b:2, c:3}; + +function ColoredTriangle() { + this.color = "red"; +} + +ColoredTriangle.prototype = triangle; + +function show_own_props(obj, objName) { + var result = ""; + + for (var prop in obj) { + if( obj.hasOwnProperty( prop ) ) { + result += objName + "." + prop + " = " + obj[prop] + "\n"; + } + } + + return result; +} + +o = new ColoredTriangle(); +alert(show_own_props(o, "o")); /* alerts: o.color = red */ +</pre> + +<h2 id="See_also" name="See_also">See also</h2> + +<ul> + <li><a href="/en-US/docs/JavaScript/Reference/Statements/for...of"><code>for...of</code></a> - a similar statement that iterates over the property <em>values</em></li> + <li><a href="/en-US/docs/JavaScript/Reference/Statements/for_each...in"><code>for each...in</code></a> - a similar statement, but iterates over the values of object's properties, rather than the property names themselves (<a href="/en-US/docs/JavaScript/New_in_JavaScript/1.6">New in JavaScript 1.6</a> but deprecated)</li> + <li><a href="/en-US/docs/JavaScript/Reference/Statements/for">for</a></li> + <li><a href="/en-US/docs/JavaScript/Guide/Iterators_and_Generators">Generator expressions</a> (uses the <code>for...in</code> syntax)</li> + <li><a href="/en-US/docs/Enumerability_and_ownership_of_properties">Enumerability and ownership of properties</a></li> + <li><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/getOwnPropertyNames"><code>getOwnPropertyNames</code></a></li> + <li><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Object/hasOwnProperty"><code>hasOwnProperty</code></a></li> + <li><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Array/forEach"><code>Array.prototype.forEach</code></a></li> +</ul> |