찾다
웹 프론트엔드프런트엔드 Q&Aes6의 새로운 루프는 무엇입니까?

es6의 새로운 루프는 무엇입니까?

Nov 07, 2022 pm 07:29 PM
javascriptes6루프 구조루프스루

ES6에는 "for of" 루프라는 새로운 루프 문이 있습니다. "for..of" 문은 전체 객체를 반복할 수 있으며 반복자에 의해 생성된 일련의 값의 루프입니다. "for..of" 루프의 값은 반복 가능해야 하며, "for(배열의 현재 값){...}" 구문. for-of 루프는 배열을 지원할 뿐만 아니라 대부분의 배열과 유사한 객체도 지원합니다. 또한 문자열 순회를 지원하고 문자열을 일련의 유니코드 문자로 순회합니다.

es6의 새로운 루프는 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, ECMAScript 버전 6, Dell G3 컴퓨터.

과거에는 for 루프와 for in 루프가 있었지만 ES6에는 새로운 루프가 있습니다. for of 루프: 전체 객체를 탐색(반복, 루프)합니다.

for..of

ES6에는 반복자에서 일련의 값을 생성하는 루프인 새로운 for..of 루프가 추가되었습니다. for..of 루프의 값은 반복 가능이어야 합니다. for..of循环,在迭代器生产的一系列值的循环。for..of循环的值必须是一个iterable

var a = ["a", "b","c","d","e"]
for(var idx in a){
    console.log(idx)
}
// 0 1 2 3 4
for(var val of a){
    console.log(val)
}
// a b c d e

for..in在数组a的键/索引上循环,for..ofa的值上循环。【相关推荐:javascript视频教程web前端

<span style="font-size: 18px;">ES6</span>之前的代码

var a = ["a", "b","c","d","e"]
for(var val, ret, it = a[Symbol.iterator]();(ret=it.next()) && !ret.done){
    val = ret.value
    console.log(val)
}
// a b c d e

在底层,for..of循环向iterable请求一个迭代器,然后反复调用这个迭代器把它产生的值赋给循环迭代变量。

JavaScript默认为iterable的标准内建值包括:

  • Array
  • Strings
  • Generators
  • Collections/TypedArrays

字符串迭代方式

for(var c of "hello"){
    console.log(c)
}
// h e l l o

原生字符串值被强制类型转换到等价的String封装对象中,它是一个iterable

<span style="font-size: 18px;">for(XYZ of ABC)</span>

对于XYZ这个位置既可以是赋值表达式,也可以是声明。下面看个赋值表达式的例子:

var o = {}
for(o.a of [1,2,3]){
    console.log(o.a)
}
o // {a:3}
for({x:o.a} of [{x:1},{x:2},{x:3}]){
    console.log(o.a)
}
o // {a:3}

通过break,continue,return提前终止循环。

自定义迭代器

通过对底层的了解,for..ofiterable请求一个迭代器,然后反复调用这个迭代器把它产生的值赋给循环迭代变量。那么我可以自定义一个iterable

var o = {
    [Symbol.iterator](){
        return this
    },
    next(){
        if(!val){
            val = 1
        }else{
            val ++
        }
        return {value:val, done:val== 6}
    }
}
for(var val of o[Symbol.iterator]()){
    console.log(val)
}

由此可见,自定义迭代器满足两个条件,[Symbol.iterator]属性,返回的对象中有next方法,next方法返回值必须是{value:xx,done:xx}的形式,如果遇到done:true

const arr = [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;];
const iter = arr[Symbol.iterator]();
 
iter.next() // { value: &#39;a&#39;, done: false }
iter.next() // { value: &#39;b&#39;, done: false }
iter.next() // { value: &#39;c&#39;, done: false }
iter.next() // { value: undefined, done: true }

for..ina 배열의 키/인덱스, afor..of를 반복합니다. > 값을 반복합니다. [관련 권장사항: javascript 비디오 튜토리얼, 웹 프런트 엔드

ES6이전 코드

window.onload=function(){ 
   const arr = [55,00, 11, 22];
   arr.name = "hello";
  // Array.prototype.FatherName = &#39;FatherName&#39;;
   /*for(let key in arr){
    console.log(&#39;key=&#39;+key+&#39;,key.value=&#39;+arr[key]);
   }*/
   /* arr.forEach((data) => {console.log(data);});*/
  /* arr.forEach((data,index,arr) => {console.log(data+&#39;,&#39;+index+&#39;,&#39;+arr);});*/
  /*for(let key of arr){
    console.log(key);
  }*/
  var string1 = &#39;abcdefghijklmn&#39;;
  var string2 = &#39;opqrstuvwxyc&#39;;
  const stringArr = [string1,string2];
  for(let key of stringArr){
    console.log(key);
  }
  for(let key of string1){
    console.log(key);
  }
}
  • 하단의 for..of 루프는 iterable에서 반복자를 요청한 다음 이 반복자를 반복적으로 호출하여 생성합니다. 값은 루프 반복 변수에 할당됩니다.
  • JavaScript기본적으로 반복 가능으로 설정되는 표준 내장 값은 다음과 같습니다.

Array

Strings
  • 생성기code>
  • Collections/TypedArrays
  • 문자열 반복 방법

var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3
기본 문자열 값은 캐스트됩니다. 동등한 문자열 캡슐화 객체에서는 반복 가능🎜

🎜🎜for(XYZ of ABC)🎜🎜🎜입니다. 🎜XYZ의 경우 이 위치는 할당 표현식이나 명령문이 될 수 있습니다. 할당 표현식의 예를 살펴보겠습니다. 🎜
var s = new Set([1, 2, 3, 3, '3']);
console.log(s); // Set {1, 2, 3, "3"}
🎜 break, continue, return을 통해 루프를 조기에 종료합니다. 🎜

🎜🎜Custom iterator🎜🎜🎜🎜기본 레이어에 대한 이해를 통해 for..ofiterable에 요청합니다. 그런 다음 이 반복자를 반복적으로 호출하여 생성된 값을 루프 반복 변수에 할당합니다. 그런 다음 iterable을 맞춤설정할 수 있습니다. 🎜
var s = new Set([1, 2, 3]);
s.add(4);
s; // Set {1, 2, 3, 4}
s.add(4);
s; // Set {1, 2, 3, 4}
🎜사용자 정의 반복자가 [Symbol.iterator] 속성 두 가지 조건을 만족하고 반환된 객체에 next 메서드인 next가 있음을 알 수 있습니다. 메서드의 반환 값은 {value:xx,done:xx} 형식이어야 합니다. done:true가 발생하면 루프가 종료됩니다. . 🎜🎜결론: 위 내용은 반복 가능한 객체를 반복할 수 있는 for..of 루프의 전체 내용입니다. 🎜🎜🎜지식 확장: for-of가 도입된 이유는 무엇인가요? 🎜🎜🎜이 질문에 답하기 위해 먼저 ES6 이전의 세 가지 for 루프의 단점을 살펴보겠습니다. 🎜🎜🎜forEach는 중단 및 반환이 불가능합니다. 🎜🎜for-in은 요소를 순회할 뿐만 아니라 배열, 사용자 정의 속성도 순회하며 프로토타입 체인의 속성에도 액세스됩니다. 또한 배열 요소가 순회되는 순서는 무작위일 수 있습니다. 🎜🎜🎜그래서 위의 결함을 고려하여 원본 for 루프를 개선해야 합니다. 하지만 ES6은 여러분이 작성한 JS 코드를 깨뜨리지 않습니다. 오늘날 수천 개의 웹 사이트가 for-in 루프에 의존하고 있으며 일부는 배열 순회에도 사용합니다. for-in 루프를 수정하여 배열 탐색 지원을 추가하면 더욱 혼란스러워질 수 있으므로 표준 위원회는 현재 문제인 for-of 를 해결하기 위해 ES6에 새로운 루프 구문을 추가했습니다. 🎜🎜그러면 for-of는 정확히 무엇을 할 수 있나요? 🎜🎜🎜forEach에 비해 break, continue, return에 올바르게 응답할 수 있습니다. 🎜🎜for-of 루프는 배열뿐만 아니라 DOM nodelist 개체와 같은 배열과 유사한 대부분의 개체도 지원합니다. 🎜🎜for-of 루프는 문자열을 일련의 유니코드 문자로 탐색하는 문자열 탐색도 지원합니다. 🎜🎜for-of는 Map 및 Set(ES6의 새로운 유형 모두) 객체 탐색도 지원합니다. 🎜🎜🎜요약하자면 for-of 루프의 특징은 다음과 같습니다. 🎜
  • 这是最简洁、最直接的遍历数组元素的语法。
  • 这个方法避开了 for-in 循环的所有缺陷。
  • 与 forEach 不同的是,它可以正确响应 break、continue 和 return 语句。
  • 其不仅可以遍历数组,还可以遍历类数组对象和其他可迭代对象。

但需要注意的是,for-of循环不支持普通对象,但如果你想迭代一个对象的属性,你可以用
for-in 循环(这也是它的本职工作)。

最后要说的是,ES6 引进的另一个方式也能实现遍历数组的值,那就是 Iterator。上个例子:

const arr = [&#39;a&#39;, &#39;b&#39;, &#39;c&#39;];
const iter = arr[Symbol.iterator]();
 
iter.next() // { value: &#39;a&#39;, done: false }
iter.next() // { value: &#39;b&#39;, done: false }
iter.next() // { value: &#39;c&#39;, done: false }
iter.next() // { value: undefined, done: true }

前面的不多说,重点描述for-of

for-of循环不仅支持数组,还支持大多数类数组对象,例如DOM NodeList对象

for-of循环也支持字符串遍历,它将字符串视为一系列的Unicode字符来进行遍历:

window.onload=function(){ 
   const arr = [55,00, 11, 22];
   arr.name = "hello";
  // Array.prototype.FatherName = &#39;FatherName&#39;;
   /*for(let key in arr){
    console.log(&#39;key=&#39;+key+&#39;,key.value=&#39;+arr[key]);
   }*/
   /* arr.forEach((data) => {console.log(data);});*/
  /* arr.forEach((data,index,arr) => {console.log(data+&#39;,&#39;+index+&#39;,&#39;+arr);});*/
  /*for(let key of arr){
    console.log(key);
  }*/
  var string1 = &#39;abcdefghijklmn&#39;;
  var string2 = &#39;opqrstuvwxyc&#39;;
  const stringArr = [string1,string2];
  for(let key of stringArr){
    console.log(key);
  }
  for(let key of string1){
    console.log(key);
  }
}

结果:

es6의 새로운 루프는 무엇입니까?

现在,只需记住:

  • 这是最简洁、最直接的遍历数组元素的语法
  • 这个方法避开了for-in循环的所有缺陷
  • 与forEach()不同的是,它可以正确响应break、continue和return语句

for-in循环用来遍历对象属性。

for-of循环用来遍历数据—例如数组中的值。

它同样支持Map和Set对象遍历。

Map和Set对象是ES6中新增的类型。ES6中的Map和Set和java中并无太大出入。

SetMap类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在Set中,没有重复的key。

要创建一个Set,需要提供一个Array作为输入,或者直接创建一个空Set

var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3

es6의 새로운 루프는 무엇입니까?

重复元素在Set中自动被过滤:

var s = new Set([1, 2, 3, 3, '3']);
console.log(s); // Set {1, 2, 3, "3"}

es6의 새로운 루프는 무엇입니까?

通过add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果:

var s = new Set([1, 2, 3]);
s.add(4);
s; // Set {1, 2, 3, 4}
s.add(4);
s; // Set {1, 2, 3, 4}

通过delete(key)方法可以删除元素:

var s = new Set([1, 2, 3]);
s; // Set {1, 2, 3}
s.delete(3);
s; // Set {1, 2}

Set对象可以自动排除重复项

var string1 = &#39;abcdefghijklmn&#39;;
  var string2 = &#39;opqrstuvwxyc&#39;;
  var string3 = &#39;opqrstuvwxyc&#39;;
  var string4 = &#39;opqrstuvwxyz&#39;;
 
  const stringArr = [string1,string2,string3,string4];
 
 
 var newSet = new Set(stringArr);
  for(let key of newSet){
    console.log(key);
  }

结果:

es6의 새로운 루프는 무엇입니까?

Map对象稍有不同:内含的数据由键值对组成,所以你需要使用解构(destructuring)来将键值对拆解为两个独立的变量:

for (var [key, value] of phoneBookMap) {   
console.log(key + "&#39;s phone number is: " + value);
}

 示例

var m = new Map([[1, &#39;Michael&#39;], [2, &#39;Bob&#39;], [3, &#39;Tracy&#39;]]);
  var map = new Map([[&#39;1&#39;,&#39;Jckey&#39;],[&#39;2&#39;,&#39;Mike&#39;],[&#39;3&#39;,&#39;zhengxin&#39;]]);
  map.set(&#39;4&#39;,&#39;Adam&#39;);//添加key-value
  map.set(&#39;5&#39;,&#39;Tom&#39;);
  map.set(&#39;6&#39;,&#39;Jerry&#39;);
  console.log(map.get(&#39;6&#39;));
  map.delete(&#39;6&#39;);
   console.log(map.get(&#39;6&#39;));
  for(var [key,value] of map) {
    console.log(&#39;key=&#39;+key+&#39; , value=&#39;+value);
  }

结果:

es6의 새로운 루프는 무엇입니까?

위 내용은 es6의 새로운 루프는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
HTML 및 React의 통합 : 실용 가이드HTML 및 React의 통합 : 실용 가이드Apr 21, 2025 am 12:16 AM

HTML 및 React는 JSX를 통해 완벽하게 통합하여 효율적인 사용자 인터페이스를 구축 할 수 있습니다. 1) JSX를 사용하여 HTML 요소를 포함시킵니다. 2) Virtual DOM을 사용하여 렌더링 성능을 최적화, 3) 구성 요소화를 통해 HTML 구조를 관리하고 렌더링합니다. 이 통합 방법은 직관적 일뿐 만 아니라 응용 프로그램 성능을 향상시킵니다.

React 및 HTML : 데이터 렌더링 및 처리 이벤트React 및 HTML : 데이터 렌더링 및 처리 이벤트Apr 20, 2025 am 12:21 AM

상태 및 소품을 통해 데이터를 효율적으로 렌더링하고 합성 이벤트 시스템을 통해 사용자 이벤트를 처리합니다. 1) usestate를 사용하여 카운터 예제와 같은 상태를 관리하십시오. 2) 버튼 클릭과 같은 JSX에 함수를 추가하여 이벤트 처리가 구현됩니다. 3) Todolist 구성 요소와 같은 목록을 렌더링하려면 주요 속성이 필요합니다. 4) 양식 처리의 경우 양식 구성 요소와 같은 usestate 및 e.preventDefault ().

백엔드 연결 : 반응이 서버와 상호 작용하는 방법백엔드 연결 : 반응이 서버와 상호 작용하는 방법Apr 20, 2025 am 12:19 AM

반응은 HTTP 요청을 통해 서버와 상호 작용하여 데이터를 획득, 전송, 업데이트 및 삭제합니다. 1) 사용자 작동 이벤트 트리거, 2) HTTP 요청 시작, 3) 프로세스 서버 응답, 4) 구성 요소 상태 및 재 렌더 업데이트.

React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.Apr 20, 2025 am 12:18 AM

React는 구성 요소 개발 및 가상 DOM을 통해 효율성을 향상시키는 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 JSX : JSX 구문을 사용하여 구성 요소를 정의하여 코드 직관과 품질을 향상시킵니다. 2. 가상 DOM 및 렌더링 : 가상 DOM 및 DIFF 알고리즘을 통해 렌더링 성능을 최적화합니다. 3. 상태 관리 및 고리 : usestate 및 useffect와 같은 후크는 상태 관리 및 부작용 처리를 단순화합니다. 4. 사용의 예 : 기본 양식에서 고급 글로벌 주 관리에 이르기까지 ContextApi를 사용하십시오. 5. 일반적인 오류 및 디버깅 : 부적절한 상태 관리 및 구성 요소 업데이트 문제를 피하고 ReactDevTools를 사용하여 디버그를 사용하십시오. 6. 성능 최적화 및 최적 성

React의 역할 : 프론트 엔드 또는 백엔드? 구별을 명확하게합니다React의 역할 : 프론트 엔드 또는 백엔드? 구별을 명확하게합니다Apr 20, 2025 am 12:15 AM

Reactisafrontendlibrary, FocusedOnBuildingUserInterfaces.itmanagesUistateAndatesefficiplyingavirtudom 및 BackingServicesViaApforDataHandling, ButDoessorsorstoredAtaitiate 스스로.

HTML에서 반응 : 대화식 사용자 인터페이스 구축HTML에서 반응 : 대화식 사용자 인터페이스 구축Apr 20, 2025 am 12:05 AM

RECT는 HTML에 내장되어 기존 HTML 페이지를 향상 시키거나 완전히 다시 작성할 수 있습니다. 1) RECT를 사용하기위한 기본 단계에는 HTML에 루트 DIV를 추가하고 ReactDom.render ()를 통해 React 구성 요소를 렌더링하는 것이 포함됩니다. 2) 더 고급 응용 프로그램에는 usestate를 사용하여 상태를 관리하고 카운터 및 할 일 목록과 같은 복잡한 UI 상호 작용을 구현하는 것이 포함됩니다. 3) 최적화 및 모범 사례에는 코드 세분화, 게으른 하중 및 React.Memo 및 Usememo 사용이 포함됩니다. 이러한 방법을 통해 개발자는 React의 힘을 활용하여 동적 및 반응 형 사용자 인터페이스를 구축 할 수 있습니다.

React : 현대 프론트 엔드 개발의 기초React : 현대 프론트 엔드 개발의 기초Apr 19, 2025 am 12:23 AM

React는 현대적인 프론트 엔드 애플리케이션을 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 가상 DOM을 사용하여 성능을 최적화합니다. 2. 구성 요소는 JSX를 사용하여 데이터를 관리하기 위해 정의, 상태 및 속성을 정의합니다. 3. 고리는 수명주기 관리를 단순화합니다. 4. ContextApi를 사용하여 글로벌 상태를 관리하십시오. 5. 일반적인 오류는 디버깅 상태 업데이트 및 수명주기가 필요합니다. 6. 최적화 기술에는 메모 화, 코드 분할 및 가상 스크롤이 포함됩니다.

React의 미래 : 웹 개발의 트렌드와 혁신React의 미래 : 웹 개발의 트렌드와 혁신Apr 19, 2025 am 12:22 AM

React의 미래는 궁극적 인 구성 요소 개발, 성능 최적화 및 다른 기술 스택과의 깊은 통합에 중점을 둘 것입니다. 1) RECT는 구성 요소의 생성 및 관리를 더욱 단순화하고 궁극적 인 구성 요소 개발을 촉진합니다. 2) 성능 최적화는 특히 대규모 응용 프로그램에서 초점이됩니다. 3) React는 개발 경험을 향상시키기 위해 GraphQL 및 TypeScript와 같은 기술과 깊이 통합 될 것입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)