aboutsummaryrefslogtreecommitdiff
path: root/files/ko
diff options
context:
space:
mode:
Diffstat (limited to 'files/ko')
-rw-r--r--files/ko/web/javascript/reference/global_objects/array/every/index.html305
1 files changed, 210 insertions, 95 deletions
diff --git a/files/ko/web/javascript/reference/global_objects/array/every/index.html b/files/ko/web/javascript/reference/global_objects/array/every/index.html
index 827b81e760..d67b5e4671 100644
--- a/files/ko/web/javascript/reference/global_objects/array/every/index.html
+++ b/files/ko/web/javascript/reference/global_objects/array/every/index.html
@@ -9,84 +9,135 @@ tags:
- Prototype
- polyfill
translation_of: Web/JavaScript/Reference/Global_Objects/Array/every
+browser-compat: javascript.builtins.Array.every
---
-<div>{{JSRef}}</div>
-<p><code><strong>every()</strong></code> 메서드는 배열 안의 모든 요소가 주어진 판별 함수를 통과하는지 테스트합니다.</p>
+<div>{{JSRef}}</div>
-<div class="blockIndicator note">
-<p><strong>참고</strong>: 빈 배열에서 호출하면 무조건 <code>true</code>를 반환합니다.</p>
-</div>
+<p>
+ <code><strong>every()</strong></code> 메서드는 배열 안의 모든 요소가 주어진 판별 함수를 통과하는지
+ 테스트합니다. Boolean 값을 반환합니다.
+</p>
-<div>{{EmbedInteractiveExample("pages/js/array-every.html")}}</div>
+<div>{{EmbedInteractiveExample("pages/js/array-every.html", 'shorter')}}</div>
+<h2 id="Syntax">Syntax</h2>
+<pre class="brush: js">
+// 화살표 함수
+every((element) => { ... } )
+every((element, index) => { ... } )
+every((element, index, array) => { ... } )
-<h2 id="구문">구문</h2>
+// 콜백 함수
+every(callbackFn)
+every(callbackFn, thisArg)
-<pre class="syntaxbox"><var>arr</var>.every(<var>callback</var>[, <var>thisArg</var>])</pre>
+// 인라인 콜백 함수
+every(function callbackFn(element) { ... })
+every(function callbackFn(element, index) { ... })
+every(function callbackFn(element, index, array){ ... })
+every(function callbackFn(element, index, array) { ... }, thisArg)
+</pre>
-<h3 id="매개변수">매개변수</h3>
+<h3 id="Parameters">매개변수</h3>
<dl>
- <dt><code>callback</code></dt>
- <dd>각 요소를 시험할 함수. 다음 세 가지 인수를 받습니다.
- <dl>
- <dt><code>currentValue</code></dt>
- <dd>처리할 현재 요소.</dd>
- <dt><code>index</code> {{Optional_inline}}</dt>
- <dd>처리할 현재 요소의 인덱스.</dd>
- <dt><code>array</code> {{Optional_inline}}</dt>
- <dd><font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.5);">every</span></font>를 호출한 배열.</dd>
- </dl>
- </dd>
- <dt><code>thisArg</code> {{Optional_inline}}</dt>
- <dd><code>callback</code>을 실행할 때 <code>this</code>로 사용하는 값.</dd>
+ <dt><code>callbackFn</code></dt>
+ <dd>
+ 각 요소를 시험할 함수. 다음 세 가지 인수를 받습니다.
+ <dl>
+ <dt>
+ <code><var>요소</var></code>
+ </dt>
+ <dd>배열에서 처리되는 현재 요소</dd>
+ <dt><code>index</code> {{Optional_inline}}</dt>
+ <dd>처리할 현재 요소의 인덱스.</dd>
+ <dt><code>array</code> {{Optional_inline}}</dt>
+ <dd><code>every</code>를 호출한 배열.</dd>
+ </dl>
+ </dd>
+ <dt><code>thisArg</code> {{Optional_inline}}</dt>
+ <dd>
+ <code><var>callbackFn</var></code
+ >을 실행할 때 <code>this</code>로 사용하는 값.
+ </dd>
</dl>
-<h3 id="반환_값">반환 값</h3>
+<h3 id="Return_value">반환 값</h3>
-<p><code>callback</code>이 모든 배열 요소에 대해 참({{Glossary("truthy")}})인 값을 반환하는 경우 <code><strong>true</strong></code>, 그 외엔 <code><strong>false</strong></code>.</p>
+<p>
+ <code>callbackFn</code>이 모든 배열 요소에 대해 참({{Glossary("truthy")}})인 값을 반환하는 경우
+ <code><strong>true</strong></code
+ >, 그 외엔 <code><strong>false</strong></code
+ >.
+</p>
-<h2 id="설명">설명</h2>
+<h2 id="Description">설명</h2>
-<p><code>every</code>는 <code>callback</code>이 {{glossary("falsy", "거짓")}}을 반환하는 요소를 찾을 때까지 배열에 있는 각 요소에 대해 한 번씩 <code>callback</code> 함수를 실행합니다. 해당하는 요소를 발견한 경우 <code>every</code>는 즉시 <code>false</code>를 반환합니다. 그렇지 않으면, 즉 모든 값에서 참을 반환하면 <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.5);">true</span></font>를 반환합니다. 할당한 값이 있는 배열의 인덱스에서만 <code>callback</code>을 호출합니다. 삭제했거나 값을 할당한 적이 없는 인덱스에서는 호출하지 않습니다.</p>
+<p>
+ <code>every</code>는 <code>callback</code>이 {{glossary("falsy", "거짓")}}을 반환하는 요소를 찾을
+ 때까지 배열에 있는 각 요소에 대해 한 번씩 <code>callbackFn</code> 함수를 실행합니다. 해당하는
+ 요소를 발견한 경우 <code>every</code>는 즉시 <code>false</code>를 반환합니다. 그렇지 않으면, 즉
+ 모든 값에서 참을 반환하면 <code>true</code>를 반환합니다.
+</p>
-<p><code>callback</code>은 요소의 값, 해당 요소의 인덱스 및 순회하고 있는 배열 세 가지 인수와 함께 호출됩니다.</p>
+<div class="notecard note">
+ <p><strong>참고:</strong> 빈 배열에서 호출하면 무조건 <code>true</code>를 반환합니다!</p>
+</div>
-<p><code>thisArg</code> 매개변수를 <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.5);">every</span></font>에 제공한 경우 <code>callback</code>의 <code>this</code>로 사용됩니다. 그 외엔 {{jsxref("undefined")}}값을 사용합니다. 최종적으로 <code>callback</code>이 볼 수 있는 <code>this</code>의 값은 <a href="/ko/docs/Web/JavaScript/Reference/Operators/this">함수가 볼 수 있는 <code>this</code>를 결정하는 평소 규칙</a>을 따릅니다.</p>
+<p>
+ 할당한 값이 있는 배열의 인덱스에서만 <code>callbackFn</code>을 호출합니다. 삭제했거나 값을 할당한
+ 적이 없는 인덱스에서는 호출하지 않습니다.
+</p>
+
+<p>
+ <code>callbackFn</code>은 요소의 값, 해당 요소의 인덱스 및 순회하고 있는 배열 세 가지 인수와 함께
+ 호출됩니다.
+</p>
+
+<p>
+ <code>thisArg</code> 매개변수를 <code>every</code>에 제공한 경우 <code>callbackFn</code>의
+ <code>this</code>로 사용됩니다. 그 외엔 {{jsxref("undefined")}}값을 사용합니다. 최종적으로
+ <code>callbackFn</code>이 볼 수 있는 <code>this</code>의 값은
+ <a href="/ko/docs/Web/JavaScript/Reference/Operators/this"
+ >함수가 볼 수 있는 <code>this</code>를 결정하는 평소 규칙</a
+ >을 따릅니다.
+</p>
<p><code>every</code>는 호출한 배열을 변형하지 않습니다.</p>
-<p><code>every</code>가 처리하는 요소의 범위는 <code>callback</code>의 첫 호출 전에 설정됩니다. <code>every</code> 호출 이후로 배열에 추가하는 요소는 <code>callback</code>이 방문하지 않습니다. 배열에 원래 있었지만 아직 방문하지 않은 요소가 <code>callback</code>에 의해 변경된 경우, 그 인덱스를 방문하는 시점의 값을 사용합니다. 삭제한 요소는 방문하지 않습니다.</p>
-
-<p><code>every</code>는 (이산)수학에서 전칭(∀) 정량자<sup>quantifier</sup>(한정자)처럼 행동합니다. 특히, 빈 배열에 대해서는 <code>true</code>를 반환합니다. (이는 <a href="http://en.wikipedia.org/wiki/Empty_set#Common_problems">공집합</a>의 모든 요소가 어떠한 주어진 조건도 만족하는 <a href="http://en.wikipedia.org/wiki/Vacuous_truth#Vacuous_truths_in_mathematics" title="vacuously true">공허한 참</a>입니다.)</p>
-
-<h2 id="예제">예제</h2>
-
-<h3 id="모든_배열_요소의_크기_테스트">모든 배열 요소의 크기 테스트</h3>
-
-<p>다음 예는 배열의 모든 요소가 10보다 더 큰지 테스트합니다.</p>
-
-<pre class="brush: js">function isBigEnough(element, index, array) {
- return element &gt;= 10;
-}
-[12, 5, 8, 130, 44].every(isBigEnough); // false
-[12, 54, 18, 130, 44].every(isBigEnough); // true
-</pre>
-
-<h3 id="화살표_함수_사용">화살표 함수 사용</h3>
-
-<p><a href="/ko/docs/Web/JavaScript/Reference/Functions/애로우_펑션">화살표 함수</a>는 같은 테스트에 대해 더 짧은 구문을 제공합니다.</p>
-
-<pre class="brush: js">[12, 5, 8, 130, 44].every(elem =&gt; elem &gt;= 10); // false
-[12, 54, 18, 130, 44].every(elem =&gt; elem &gt;= 10); // true</pre>
-
-<h2 id="폴리필">폴리필</h2>
-
-<p><code>every</code>는 ECMA-262 표준 제5판에 추가됐으므로 어떤 표준 구현체에서는 사용하지 못할 수도 있습니다. 다른 모든 코드 이전에 아래 코드를 포함하면 <code>every</code>를 지원하지 않는 환경에서도 사용할 수 있습니다. 아래 알고리즘은 {{jsxref("Object")}}와 {{jsxref("TypeError")}}가 변형되지 않고, <code>callbackfn.call</code>의 계산 값이 원래의 {{jsxref("Function.prototype.call()")}}과 같은 경우 ECMA-262 제5판이 명시한 것과 동일합니다.</p>
-
-<pre class="brush: js">if (!Array.prototype.every) {
+<p>
+ <code>every</code>가 처리하는 요소의 범위는 <code>callbackFn</code>의 첫 호출 전에 설정됩니다.
+ <code>every</code> 호출 이후로 배열에 추가하는 요소는 <code>callbackFn</code>이 방문하지 않습니다.
+ 배열에 존재하는 요소가 변경된 경우, <code>callbackFn</code>에 <code>every</code>가 방문하는 시점의
+ 값을 전달합니다. 삭제한 요소는 방문하지 않습니다.
+</p>
+
+<p>
+ <code>every</code>는 (이산)수학에서 전칭(∀) 정량자<sup>quantifier</sup>(한정자)처럼 행동합니다.
+ 특히, 빈 배열에 대해서는 <code>true</code>를 반환합니다. (이는
+ <a href="http://en.wikipedia.org/wiki/Empty_set#Common_problems">공집합</a>의 모든 요소가 어떠한
+ 주어진 조건도 만족하는
+ <a
+ href="http://en.wikipedia.org/wiki/Vacuous_truth#Vacuous_truths_in_mathematics"
+ title="vacuously true"
+ >공허한 참</a
+ >입니다.)
+</p>
+
+<h2 id="Polyfill">폴리필</h2>
+
+<p>
+ <code>every</code>는 ECMA-262 표준 제5판에 추가됐으므로 어떤 표준 구현체에서는 사용하지 못할 수도
+ 있습니다. 다른 모든 코드 이전에 아래 코드를 포함하면 <code>every</code>를 지원하지 않는 환경에서도
+ 사용할 수 있습니다. 아래 알고리즘은 {{jsxref("Object")}}와 {{jsxref("TypeError")}}가 변형되지
+ 않고, <code>callbackfn.call</code>의 계산 값이 원래의 {{jsxref("Function.prototype.call")}}과 같은
+ 경우 ECMA-262 제5판이 명시한 것과 동일합니다.
+</p>
+
+<pre class="brush: js">
+if (!Array.prototype.every) {
Array.prototype.every = function(callbackfn, thisArg) {
'use strict';
var T, k;
@@ -148,44 +199,108 @@ translation_of: Web/JavaScript/Reference/Global_Objects/Array/every
}
return true;
};
-}</pre>
-
-<h2 id="명세">명세</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">명세</th>
- <th scope="col">상태</th>
- <th scope="col">설명</th>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.4.4.16', 'Array.prototype.every')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td>초기 정의. JavaScript 1.6에서 구현됨.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-array.prototype.every', 'Array.prototype.every')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-array.prototype.every', 'Array.prototype.every')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="브라우저_호환성">브라우저 호환성</h2>
-
-<p>{{Compat("javascript.builtins.Array.every")}}</p>
-
-<h2 id="같이_보기">같이 보기</h2>
+}
+</pre>
+
+<h2 id="Examples">예제</h2>
+
+<h3 id="Testing_size_of_all_array_elements">모든 배열 요소의 크기 테스트</h3>
+
+<p>다음 예는 배열의 모든 요소가 10보다 더 큰지 테스트합니다.</p>
+
+<pre class="brush: js">
+function isBigEnough(element, index, array) {
+ return element &gt;= 10;
+}
+[12, 5, 8, 130, 44].every(isBigEnough); // false
+[12, 54, 18, 130, 44].every(isBigEnough); // true
+</pre>
+
+<h3 id="Using_arrow_functions">화살표 함수 사용</h3>
+
+<p>
+ <a href="/ko/docs/Web/JavaScript/Reference/Functions/Arrow_functions">화살표 함수</a>는 같은
+ 테스트에 대해 더 짧은 구문을 제공합니다.
+</p>
+
+<pre class="brush: js">
+[12, 5, 8, 130, 44].every(elem =&gt; elem &gt;= 10); // false
+[12, 54, 18, 130, 44].every(elem =&gt; elem &gt;= 10); // true</pre
+>
+
+<h3 id="Affecting_Initial_Array_modifying_appending_and_deleting">
+ 초기 배열에 영향주기(수정, 추가, 삭제)
+</h3>
+
+<p>아래 예제는 배열이 수정될 때 <code>every</code> 메서드의 행위를 테스트합니다.</p>
+
+<pre class="brush: js">
+// ---------------
+// 요소 수정
+// ---------------
+let arr = [1, 2, 3, 4];
+arr.every( (elem, index, arr) =&gt; {
+ arr[index+1] -= 1
+ console.log(`[${arr}][${index}] -&gt; ${elem}`)
+ return elem &lt; 2
+})
+
+// 3회 순회하지만 앞선 2회의 순회는 수정이 일어나지 않습니다.
+//
+// 1st iteration: [1,1,3,4][0] -&gt; 1
+// 2nd iteration: [1,1,2,4][1] -&gt; 1
+// 3rd iteration: [1,1,2,3][2] -&gt; 2
+
+// ---------------
+// 요소 추가
+// ---------------
+arr = [1, 2, 3];
+arr.every( (elem, index, arr) =&gt; {
+ arr.push('new')
+ console.log(`[${arr}][${index}] -&gt; ${elem}`)
+ return elem &lt; 4
+})
+
+// 새로운 요소가 추가된 후에도 3회 순회합니다.
+//
+// 1st iteration: [1, 2, 3, new][0] -&gt; 1
+// 2nd iteration: [1, 2, 3, new, new][1] -&gt; 2
+// 3rd iteration: [1, 2, 3, new, new, new][2] -&gt; 3
+
+// ---------------
+// 요소 삭제
+// ---------------
+arr = [1, 2, 3, 4];
+arr.every( (elem, index, arr) =&gt; {
+ arr.pop()
+ console.log(`[${arr}][${index}] -&gt; ${elem}`)
+ return elem &lt; 4
+})
+
+// 기존 요소가 `pop()` 됨에 따라 2회만 순회합니다.
+//
+// 1st iteration: [1,2,3][0] -&gt; 1
+// 2nd iteration: [1,2][1] -&gt; 2
+</pre>
+
+<h2 id="Specifications">명세</h2>
+
+{{Specifications}}
+
+<h2 id="Browser_compatibility">브라우저 호환성</h2>
+
+<p>{{Compat}}</p>
+
+<h2 id="See_also">같이 보기</h2>
<ul>
- <li>{{jsxref("Array.prototype.forEach()")}}</li>
- <li>{{jsxref("Array.prototype.some()")}}</li>
- <li>{{jsxref("Array.prototype.find()")}}</li>
- <li>{{jsxref("TypedArray.prototype.every()")}}</li>
+ <li>
+ <code>Array.prototype.every</code>의 폴리필은
+ <a href="https://github.com/zloirock/core-js#ecmascript-array"><code>core-js</code></a
+ >에서 가능합니다
+ </li>
+ <li>{{jsxref("Array.prototype.forEach()")}}</li>
+ <li>{{jsxref("Array.prototype.some()")}}</li>
+ <li>{{jsxref("Array.prototype.find()")}}</li>
+ <li>{{jsxref("TypedArray.prototype.every()")}}</li>
</ul>