JavaScript_javascript 기술에 포함된 배열 개체의 내장 메서드 소개
/**
* 이 글은 순전히 현재 W3C 표준에 내장된 배열 객체의 메소드를 정리하기 위한 것입니다.
* 전체 내용은 영양가가 없지만 성능 테스트의 마지막 부분에서 몇 가지 질문이 제기됩니다.
*/
Mutator 메소드
이러한 메소드는 배열 자체를 직접 수정합니다
pop 및 push
Array.pop (); // 배열의 마지막 요소를 삭제하고 삭제된 요소를 반환합니다.
Array.push(element1, ..., elementN) // 배열의 끝에 1-N 요소를 삽입하고 배열의 길이를 반환합니다. 작업 후
이러한 pop 및 push를 통해 배열을 스택으로 시뮬레이션하여 작업할 수 있습니다.
스택 데이터 구조의 특징은 "후입 선출(LIFO, Last In First Out)"입니다.
shift 및 unshift
Array.shift(); // 배열의 첫 번째 요소를 삭제하고 삭제된 요소를 반환합니다.
Array.unshift(element1, ..., elementN) ; // 배열의 헤드에 1-N 요소를 삽입하고 작업 후 배열의 길이를 반환합니다.
큐 작업을 구현하려면 Shift 및 unshift를 사용하세요.
큐의 작동 모드는 스택의 작동 모드와 반대이며 "선입선출"(FIFO, First-In-First-Out)을 사용합니다.
접속
Array.splice(index, HowMany[, element1[, ...[, elementN]]])
Array.splice(index)
인덱스: 요소 추가/제거를 지정하는 위치입니다.
howmany: 삭제해야 하는 요소 수를 지정합니다.
elements: 인덱스가 가리키는 아래 첨자부터 시작하여 배열에 추가할 새 요소를 지정합니다.
스플라이스 방식은 팝(pop), 푸시(push), 시프트(shift), 언시프트(unshift)를 보완하는 방식입니다.
반환값은 삭제된 요소입니다.
역방향
sort
아니요 매개변수는 이 메소드를 호출할 때 사용되며 배열의 요소를 알파벳순으로 정렬합니다.
더 정확하게는 문자 인코딩 순서에 따라 정렬됩니다.
•a가 b보다 작으면 정렬된 배열에서 a가 b 앞에 나타나야 하고 0보다 작은 값을 반환합니다.
•a가 b와 같으면 0을 반환합니다.
•a가 b보다 큰 경우 0보다 큰 값을 반환합니다.
---------------------------------- --- ----------------------------------
접속자 방법
이 메소드는 배열 자체를 수정하지 않고 해당 결과를 반환합니다concat
그러나 주의해야 할 사항이 하나 있는데, 이는 다음 예에서 설명됩니다.
arr.concat([4, 5], [6, 7]) // return [ 1, 2, 3, 4, 5, 6, 7]
arr.concat(4, [5, [6, 7]]) // return [1, 2, 3, 4, 5, [6] , 7]]
join
string = Array.join(separator) 배열의 모든 요소를 문자열에 넣습니다. 그 중 요소는 지정된 구분 기호로 구분됩니다. 기본 구분 기호는 쉼표(,)이며, 반환 값은 결합된 문자열입니다.
[1, 2, 3].join(); // return "1,2,3"Array.join() 메서드는 실제로 String.splite()의 반대 작업입니다.
슬라이스
toString
Array.toString(); // 이에 대해서는 더 이상 이야기하지 않겠습니다. 모든 JavaScript에는
indexOf 및 lastIndexOf *[ECMAScript 5]
처음부터 배열 검색 .lastIndexOf(searchElement[, fromIndex]); // 끝부터 검색
fromIndex: 시작 위치를 나타내는 인덱스 검색
------ ---------------------------- --------- -------------
각 반복 방법
*[ECMAScript 5] / / 배열을 처음부터 끝까지 순회하고, 배열의 각 요소에 대해 지정된 함수를 호출합니다.
코드는 다음과 같습니다.
[1, 2].forEach(function(value, index, array) {
console.log(값, 인덱스, 배열)
})
코드 복사
코드는 다음과 같습니다.
try {
[1,2 ,3] .forEach(function(val) {
console.log(val);
*[ECMAScript 5]
Array.map(callback[, thisArg]); // 배열 요소를 탐색하고 호출합니다. 지정된 함수 및 모든 결과를 배열로 반환
매개 변수:
콜백: 배열을 순회할 때 호출되는 함수
thisObject: 콜백 범위 지정
예:
코드 복사
코드는 다음과 같습니다.
[1, 2, 3].map(function(num) { / / return [2, 3, 4]
return num 1;
})
코드 복사
코드는 다음과 같습니다.
Array.filter(callback[, thisObject]) // 배열 탐색 조건을 충족하는 요소(true 반환)는 반환 값 배열에 추가됩니다.
[1, 2, 3].filter(function(num) { // return [1]
return num < 2;
}); 🎜>모든 것
Array.every(callback[, thisObject]); // "AND"
Array.some(callback[, thisObject]) // "또는"
매개변수: 콜백: 배열을 순회할 때 호출되는 함수
thisObject: 콜백의 범위를 지정합니다.
코드는 다음과 같습니다.
[1, 2, 3].every(function(num) { // return false
return num > 1;
[1, 2, 3] . some(function(num) { // true를 반환합니다
return num > 2;
})
reduce 및 축소 *[ECMAScript 5] // 지정된 방법을 사용하여 낮은 것부터 높은 것까지(왼쪽에서 오른쪽으로) 배열 요소를 결합합니다. Array.reduceRight(callback[,initialValue]) // 지정된 방법을 사용하여 Index에 따라 배열 요소를 결합합니다. 높음에서 낮음(오른쪽에서 왼쪽)
예:
[1, 2, 3].reduce(function(x, y) { // return 106
return x y;
------ --- ---------------------------------- --- -------
성능 테스트
테스트 시스템: Windows 7
테스트 브라우저: Chrome 26.0 .1386.0
코드 복사
코드는 다음과 같습니다.
var arr = []
for(var i = 0; i < 999999; i ) {
코드 복사
코드는 다음과 같습니다.
function forEachTest() { howTime ("forEach", function() {
var num = 0;
});
}
다음은 3번의 무작위 테스트 결과입니다. (구체적인 결과는 컴퓨터 구성과 관련이 있으며, 크기가 작을수록 결과가 좋을수록 성능이 좋아집니다):
time_forEach |
time_for |
1421.000ms | 64.000ms |
1641.000ms | 63.000ms |
1525.000ms | 63.000ms |
보시다시피 Chrome은 forEach를 특별히 최적화하지 않았습니다. for 루프 순회를 직접 사용하는 것과 비교하면 성능이 여전히 더 좋습니다. 큰 격차.
forEach는 ECMAScript 5이므로 이전 브라우저에서는 이를 지원하지 않습니다.
그러나 MDN은 이전 버전과 호환되는 솔루션을 제공했습니다.
코드 복사
time_forEach | time_for |
1421.000ms | 64.000ms |
1641.000ms | 63.000ms |
1525.000ms | 63.000ms |
코드는 다음과 같습니다.
이상한 점은 성능 측면에서 기본 forEach 메서드는 실제로 직접 구성한 forEach만큼 좋지 않습니다!
또한 다른 Array 객체의 다른 반복 방법은 어떻습니까?
이 데모를 보시면 기본적으로 이해하실 것입니다: http://maplejan.sinaapp.com/demo/ArratMethod.html
또한 흥미로운 상황도 발견했습니다.
데모 자바스크립트 코드를 콘솔에서 직접 실행해 보면 성능에서 큰 차이를 느낄 수 있습니다!
이때 for 루프를 사용하여 직접 작성하는 성능은 더욱 저하됩니다.
이 질문에 대해 Zhihu에 질문했습니다. 질문 주소는 http://www.zhihu.com/question/20837774입니다.

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

이 튜토리얼은 Chart.js를 사용하여 파이, 링 및 버블 차트를 만드는 방법을 설명합니다. 이전에는 차트 유형의 차트 유형을 배웠습니다. JS : 라인 차트 및 막대 차트 (자습서 2)와 레이더 차트 및 극지 지역 차트 (자습서 3)를 배웠습니다. 파이 및 링 차트를 만듭니다 파이 차트와 링 차트는 다른 부분으로 나뉘어 진 전체의 비율을 보여주는 데 이상적입니다. 예를 들어, 파이 차트는 사파리에서 남성 사자, 여성 사자 및 젊은 사자의 비율 또는 선거에서 다른 후보자가받는 투표율을 보여주는 데 사용될 수 있습니다. 파이 차트는 단일 매개 변수 또는 데이터 세트를 비교하는 데만 적합합니다. 파이 차트의 팬 각도는 데이터 포인트의 숫자 크기에 의존하기 때문에 원형 차트는 값이 0 인 엔티티를 그릴 수 없습니다. 이것은 비율이 0 인 모든 엔티티를 의미합니다

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

엔트리 레벨 타입 스크립트 자습서를 마스터 한 후에는 TypeScript를 지원하고 JavaScript로 컴파일하는 IDE에서 자신의 코드를 작성할 수 있어야합니다. 이 튜토리얼은 TypeScript의 다양한 데이터 유형으로 뛰어납니다. JavaScript에는 NULL, UNDEFINED, BOOLEAN, 번호, 문자열, 기호 (ES6에 의해 소개 됨) 및 객체의 7 가지 데이터 유형이 있습니다. TypeScript는이 기반으로 더 많은 유형을 정의 하며이 튜토리얼은이 모든 튜토리얼을 자세히 다룹니다. 널 데이터 유형 JavaScript와 마찬가지로 Null in TypeScript
