5가지 배열 배열 방법: indexOf, filter, forEach, map, 줄이기 사용 사례_javascript 기술
ECMAScript5 표준은 2009년 12월 3일에 출시되었습니다. 이는 기존 배열 배열 작업을 개선하는 몇 가지 새로운 방법을 제공합니다. 그러나 당시 시장에는 ES5 지원 브라우저가 부족했기 때문에 이러한 새로운 배열 방법은 실제로 인기를 끌지 못했습니다.
배열 "추가"
아무도 이러한 방법의 실용성을 의심하지 않지만 폴리필(PS: 이전 브라우저와 호환되는 플러그인)을 작성하는 것은 그럴 가치가 없습니다. "반드시 달성해야 한다"를 "최상 달성"으로 바꿉니다. 어떤 사람들은 실제로 이러한 배열 메소드를 Array "Extras"라고 부릅니다. 왜!
하지만 시대가 변하고 있습니다. Github에서 인기 있는 오픈 소스 JS 프로젝트를 살펴보면 흐름이 바뀌고 있음을 알 수 있습니다. 모든 사람은 (타사 라이브러리에 대한) 많은 종속성을 줄이고 이를 달성하기 위해 로컬 코드만 사용하기를 원합니다.
자, 시작해 보겠습니다.
나의 어레이 5개
ES5에는 총 9가지 Array 메소드가 있습니다 http://kangax.github.io/compat-table/es5/
참고* 9가지 방법
Array.prototype.indexOf
Array.prototype.lastIndexOf
Array.prototype.every
Array.prototype.some
Array.prototype.forEach
배열.프로토타입.맵
배열.프로토타입.필터
배열.프로토타입.리듀스
Array.prototype.reduceRight
개인적으로 가장 유용하고 많은 개발자들이 접하게 될 방법 5가지를 꼽아보겠습니다.
1) indexOf
indexOf() 메서드는 배열에서 발견된 첫 번째 요소의 위치를 반환하거나, 존재하지 않는 경우 -1을 반환합니다.
indexOf를 사용하지 않는 경우
var arr = ['apple','orange','pear'], found = false; for(var i= 0, l = arr.length; i< l; i++){ if(arr[i] === 'orange'){ found = true; } } console.log("found:",found);
사용 후
var arr = ['apple','orange','pear']; console.log("found:", arr.indexOf("orange") != -1);
2) 필터
filter() 메서드는 필터 조건과 일치하는 새 배열을 생성합니다.
filter()를 사용하지 않는 경우
var arr = [ {"name":"apple", "count": 2}, {"name":"orange", "count": 5}, {"name":"pear", "count": 3}, {"name":"orange", "count": 16}, ]; var newArr = []; for(var i= 0, l = arr.length; i< l; i++){ if(arr[i].name === "orange" ){ newArr.push(arr[i]); } } console.log("Filter results:",newArr);
사용된 필터():
var arr = [ {"name":"apple", "count": 2}, {"name":"orange", "count": 5}, {"name":"pear", "count": 3}, {"name":"orange", "count": 16}, ]; var newArr = arr.filter(function(item){ return item.name === "orange"; }); console.log("Filter results:",newArr);
3) forEach()
forEach는 각 요소에 해당하는 메소드를 실행합니다
var arr = [1,2,3,4,5,6,7,8]; // Uses the usual "for" loop to iterate for(var i= 0, l = arr.length; i< l; i++){ console.log(arr[i]); } console.log("========================"); //Uses forEach to iterate arr.forEach(function(item,index){ console.log(item); });
forEach는 for 루프를 대체하는 데 사용됩니다
4) 지도()
map()은 배열의 각 요소에 대해 특정 작업(매핑)을 수행한 후 새 배열을 반환합니다.
지도 사용 금지
var oldArr = [{first_name:"Colin",last_name:"Toh"},{first_name:"Addy",last_name:"Osmani"},{first_name:"Yehuda",last_name:"Katz"}]; function getNewArr(){ var newArr = []; for(var i= 0, l = oldArr.length; i< l; i++){ var item = oldArr[i]; item.full_name = [item.first_name,item.last_name].join(" "); newArr[i] = item; } return newArr; } console.log(getNewArr());
지도 이용 후
var oldArr = [{first_name:"Colin",last_name:"Toh"},{first_name:"Addy",last_name:"Osmani"},{first_name:"Yehuda",last_name:"Katz"}]; function getNewArr(){ return oldArr.map(function(item,index){ item.full_name = [item.first_name,item.last_name].join(" "); return item; }); } console.log(getNewArr());
map()은 서버에서 반환된 데이터를 처리할 때 매우 실용적인 함수입니다.
5) 축소()
reduce()는 배열의 각 값(왼쪽에서 오른쪽으로)을 값으로 줄이는 누산기 기능을 구현할 수 있습니다.
솔직히 이 문장은 너무 추상적이어서 처음에는 이해하기 조금 어려웠습니다.
시나리오: 배열에 고유한 단어가 몇 개 있는지 세어보세요
리듀스를 사용하지 않는 경우
var arr = ["apple","orange","apple","orange","pear","orange"]; function getWordCnt(){ var obj = {}; for(var i= 0, l = arr.length; i< l; i++){ var item = arr[i]; obj[item] = (obj[item] +1 ) || 1; } return obj; } console.log(getWordCnt());
reduce() 사용 후
var arr = ["apple","orange","apple","orange","pear","orange"]; function getWordCnt(){ return arr.reduce(function(prev,next){ prev[next] = (prev[next] + 1) || 1; return prev; },{}); } console.log(getWordCnt());
먼저 제가 Reduce에 대해 어떻게 이해하고 있는지부터 설명하겠습니다. Reduce(callback,initialValue)는 두 개의 변수를 전달합니다. 콜백 함수(callback)와 초기값(initialValue)입니다. 함수에 들어오는 매개변수인 prev와 next, index와 array가 있다고 가정합니다. 이전과 다음을 이해해야 합니다.
일반적으로 prev는 배열의 첫 번째 요소부터 시작하고 next는 두 번째 요소입니다. 그러나 초기 값(initialValue)을 전달하면 첫 번째 prev는initialValue가 되고 next는 배열의 첫 번째 요소가 됩니다.
예:
/* * 二者的区别,在console中运行一下即可知晓 */ var arr = ["apple","orange"]; function noPassValue(){ return arr.reduce(function(prev,next){ console.log("prev:",prev); console.log("next:",next); return prev + " " +next; }); } function passValue(){ return arr.reduce(function(prev,next){ console.log("prev:",prev); console.log("next:",next); prev[next] = 1; return prev; },{}); } console.log("No Additional parameter:",noPassValue()); console.log("----------------"); console.log("With {} as an additional parameter:",passValue());

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











application.yml은 목록 컬렉션을 정의합니다. 첫 번째 방법은 @ConfigurationProperties 주석을 사용하여 목록 컬렉션 유형:code:status:-200-300-400-500의 모든 값을 얻는 것입니다. 여기서 주목해야 할 점은 목록 Collection을 정의하고 먼저 구성 클래스 Bean을 정의한 다음 @ConfigurationProperties 주석을 사용하여 목록 컬렉션 값을 얻는다는 것입니다. @Component는 엔티티 클래스를 Spring 관리 @ConfigurationPropertie에 넘겨줍니다.

1. Iterator와 foreach의 차이점은 다형성 차이입니다(foreach의 맨 아래 레이어는 Iterator입니다). Iterator는 인터페이스 유형이므로 컬렉션 유형이나 배열에 관심이 없습니다. for와 foreach 모두 컬렉션 유형을 알아야 합니다. 1. foreach의 최하위 레이어가 Iterator에 의해 작성된 코드라고 말하는 이유: 디컴파일된 코드: 2. foreach와 iterator에서 제거의 차이점을 살펴보세요. Alibaba Java Development Manual, 그러나 1번의 경우에는 오류가 보고되지 않으며, 2번의 경우(java.util.ConcurrentModificationException) 먼저 오류가 보고됩니다.

PHP가 foreach 루프 수를 결정하는 단계: 1. "$fruits" 배열을 만듭니다. 2. 초기 값이 0인 카운터 변수 "$counter"를 만듭니다. 3. "foreach"를 사용하여 루프를 만듭니다. 배열을 통해 루프 본문의 카운터 변수 값을 늘린 다음 각 요소와 해당 인덱스를 출력합니다. 4. "foreach" 루프 외부에 카운터 변수 값을 출력하여 루프가 도달하는 요소를 확인합니다.

1. 기술적 배경 실제 프로젝트 개발에서는 시스템의 가용성과 견고성을 향상시키기 위해 캐싱 미들웨어(예: redis, MemCache 등)를 자주 사용합니다. 하지만 프로젝트가 상대적으로 단순하다면 캐싱을 사용하기 위해 시스템의 복잡성을 높이기 위해 Redis와 같은 미들웨어를 특별히 도입할 필요가 없는 경우가 많습니다. 그렇다면 Java 자체에는 유용한 경량 캐싱 구성 요소가 있습니까? 물론 대답은 '그렇다'이며, 방법은 여러 가지가 있습니다. 일반적인 솔루션에는 ExpiringMap, LoadingCache 및 HashMap 기반 패키징이 포함됩니다. 2. 오래된 삭제 전략, 핫스팟 데이터 워밍업 등 캐시의 공통 기능을 구현하기 위한 기술적 효과 3. ExpiringMap3.

javabeans와 map을 변환하는 방법에는 여러 가지가 있습니다. 1. ObjectMapper를 통해 Bean을 json으로 변환한 다음 json을 map으로 변환합니다. 그러나 이 방법은 테스트 후에 10,000개의 Bean이 루프로 변환되었습니다. 12초 걸립니다! ! ! 2. Java Reflection을 통해 Bean 클래스의 속성과 값을 얻은 다음 이를 맵에 해당하는 키-값 쌍으로 변환하는 방법이 두 번째로 좋지만 조금 더 번거롭습니다. 3. 클래스의 net.sf.cglib.beans.BeanMap 메소드를 통해 이 메소드는 매우 효율적입니다. 두 번째 메소드와 차이점은 캐시를 사용하기 때문에 첫 번째 Bean을 생성할 때 초기화해야 한다는 것입니다. 시간.

방법 1. HashtableMapashtable=newHashtable();을 사용하세요. 이것이 모두가 가장 먼저 생각하는 것인데, 왜 스레드로부터 안전할까요? 그런 다음 소스 코드를 살펴보면 put, get 및 containKey와 같이 일반적으로 사용되는 메서드가 모두 동기식이므로 스레드로부터 안전한 publicsynchronizedbooleancontainsKey(Objectkey){Entrytab[]=table;inthash=key임을 알 수 있습니다. hashCode( );intindex=(hash&0x7FFFFFFF)%tab.leng

이 기사에서는 키 값을 뒤집은 후 PHP가 배열을 반환하는 방법을 자세히 설명합니다. 편집자는 이것이 매우 실용적이라고 생각하므로 이 기사를 읽고 뭔가를 얻을 수 있기를 바랍니다. PHP 키 값 뒤집기 배열 키 값 뒤집기는 배열의 키와 값을 교환하여 원래 키를 값으로, 원래 값을 키로 사용하여 새 배열을 생성하는 배열 작업입니다. 구현 방법 PHP에서는 다음 방법을 통해 배열의 키-값 뒤집기를 수행할 수 있습니다. array_flip() 함수: array_flip() 함수는 키-값 뒤집기 작업에 특별히 사용됩니다. 배열을 인수로 받고 키와 값이 교환된 새 배열을 반환합니다. $original_array=[

Go 언어 맵의 성능 최적화 Go 언어에서 맵은 키-값 쌍 모음을 저장하는 데 사용되는 매우 일반적으로 사용되는 데이터 구조입니다. 그러나 대량의 데이터를 처리하는 경우 지도 성능이 저하될 수 있습니다. 지도의 성능을 향상시키기 위해 몇 가지 최적화 조치를 취하여 지도 작업의 시간 복잡성을 줄여 프로그램의 실행 효율성을 향상시킬 수 있습니다. 1. 맵 용량을 사전 할당합니다. 맵 생성 시 용량을 사전 할당하여 맵 확장 횟수를 줄이고 프로그램 성능을 향상시킬 수 있습니다. 일반적으로 우리는
