ES6 입문 튜 토리 얼 의 Array.from()방법
3398 단어 es6array.from()방법.
ES6 는 Array 에 from 함 수 를 추가 하여 다른 대상 을 배열 로 변환 합 니 다.
물론 다른 대상 도 요구 가 있 고 모든 것 이 아니 라 두 대상 을 배열 로 바 꿀 수 있다.
1.Iterator 인터페이스의 대상 을 배치 했다.예 를 들 어 Set,Map,Array.
2.클래스 배열 대상,클래스 배열 대상 이 라 니 요?한 대상 은 length 속성 이 있어 야 합 니 다.length 가 없 으 면 빈 배열 로 전 환 됩 니 다.
Array.from()방법 은 하나의 배열 대상 이나 옮 겨 다 닐 수 있 는 대상 을 진정한 배열 로 바 꾸 는 것 이다.
그렇다면 클래스 배열 대상 은 무엇 일 까?클래스 배열 대상 이란 가장 기본 적 인 요 구 는 length 속성 을 가 진 대상 이다.
1.클래스 배열 대상 을 실제 배열 로 변환 합 니 다.
let arrayLike = {
0: 'tom',
1: '65',
2: ' ',
3: ['jane','john','Mary'],
'length': 4
}
let arr = Array.from(arrayLike)
console.log(arr) // ['tom','65',' ',['jane','john','Mary']]
그렇다면 위의 코드 에서 length 속성 을 제거 하면?정 답 은 길이 가 0 인 빈 배열 임 을 증명 한다.여기 서 코드 를 다시 바 꾸 면 length 속성 이 있 지만 대상 의 속성 명 은 더 이상 숫자 형식 이 아니 라 다른 문자열 형 입 니 다.코드 는 다음 과 같 습 니 다.
let arrayLike = {
'name': 'tom',
'age': '65',
'sex': ' ',
'friends': ['jane','john','Mary'],
length: 4
}
let arr = Array.from(arrayLike)
console.log(arr) // [ undefined, undefined, undefined, undefined ]
결 과 는 길이 가 4 이 고 요소 가 모두 undefined 인 배열 임 을 발견 할 수 있 습 니 다.이 를 통 해 알 수 있 듯 이 하나의 배열 대상 을 진정한 배열 로 바 꾸 려 면 다음 과 같은 조건 을 가 져 야 한다.
1.이 배열 의 대상 은 length 속성 을 가지 고 배열 의 길 이 를 지정 해 야 합 니 다.length 속성 이 없 으 면 변환 한 배열 은 빈 배열 입 니 다.
2.이러한 배열 대상 의 속성 명 은 수치 형 이나 문자열 형의 숫자 여야 합 니 다.
이러한 배열 대상 의 속성 명 은 따옴표 를 추가 할 수도 있 고 따옴표 를 추가 하지 않 을 수도 있다.
2.Set 구조의 데 이 터 를 진정한 배열 로 변환 합 니 다.
let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set)) // [ 12, 45, 97, 9797, 564, 134, 45642 ]
Array.from 은 두 번 째 인 자 를 받 아들 일 수 있 습 니 다.배열 과 유사 한 map 방법 으로 모든 요 소 를 처리 하고 처리 한 값 을 되 돌아 오 는 배열 에 넣 을 수 있 습 니 다.다음 과 같다.
let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set, item => item + 1)) // [ 13, 46, 98, 9798, 565, 135, 45643 ]
1~20 개의 배열 을 빠르게 만 듭 니 다.
Array.from({length:20},(t,i)=>i+1)
// [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
아 날로 그 생 성 1 만 개 데이터
// 1 , Array.from
const originNews = Array.from(
{ length: 10000 },
(v, k) => ({ content: ` ${k}` })
)
3.문자열 을 배열 로 변환 합 니 다:
let str = 'hello world!';
console.log(Array.from(str)) // ["h", "e", "l", "l", "o", " ", "w", "o", "r", "l", "d", "!"]
4.Array.from 인 자 는 진정한 배열 입 니 다.
console.log(Array.from([12,45,47,56,213,4654,154]))
이 경우 Array.from 은 똑 같은 새 배열 로 돌아 갑 니 다.배열 을 지정 한 크기 로 나 누 면 페이지,데이터 절단,비동기 작업 데이터 에 사용 할 수 있 습 니 다.
const chunk = (arr, size) =>
Array.from({ length: Math.ceil(arr.length / size) }, (v, i) =>
arr.slice(i * size, i * size + size)
);
총결산이상 은 이 글 의 모든 내용 입 니 다.본 고의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 참고 학습 가 치 를 가지 기 를 바 랍 니 다.여러분 의 저희 에 대한 지지 에 감 사 드 립 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JavaScript로 카드 놀이를 넘기는 애니메이션을 만들려고했습니다.카드를 넘기는 애니메이션을 만들어 보았습니다. 폴더 구성은 다음과 같습니다. 코드는 다음과 같습니다. card_turning.html 다음은 JavaScript 코드입니다. cardTurning.js 결과는, 이런 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.