찾다
웹 프론트엔드JS 튜토리얼마스터해야 할 js에서 배열을 생성하는 방법에 대한 자세한 설명(순수 코드)

JS에서 배열을 만드는 방법은 여러 가지가 있는데, 어떤 방법을 알고 있나요? 구체적으로 다음을 살펴보세요:

join(), push() 및 pop(), Shift() 및 unshift(), sort(), reverse(), concat(), Slice(), splice(), indexOf( ) 및 lastIndexOf()(ES5의 새로운 기능), forEach()(ES5의 새로운 기능), map()(ES5의 새로운 기능), filter()(ES5의 새로운 기능), Every()(ES5의 새로운 기능), some() ( ES5 신규), Reduce() 및 ReduceRight() (ES5 신규)

// 1、join(separator): 将数组的元素组起一个字符串,以separator为分隔符,省略的话则用默认用逗号为分隔符,
    // 该方法只接收一个参数:即分隔符。原数组不变
    var arr = [1, 2, 3];
    console.log(arr.join()); // 1,2,3
    console.log(arr.join("-")); // 1-2-3
    console.log(arr); // [1, 2, 3](原数组不变)

    // 2.push(): 添加到数组末尾,返回新数组。 参数最少一个
    // pop():数组末尾移除最后一项,返回新数组
    var arr = ["Lily", "lucy", "Tom"];
    var count = arr.push("Jack", "Sean");
    console.log(count); // 5
    console.log(arr); // ["Lily", "lucy", "Tom", "Jack", "Sean"]
    var newArr = ["Lily", "lucy", "Tom", "Jack", "Sean"]
    var item = newArr.pop();
    console.log(item); // Sean
    console.log(newArr); // ["Lily", "lucy", "Tom", "Jack"]

    // 3.shift():删除原数组第一项,返回新数组 。 
    // unshift:将参数添加到原数组开头,返回新数组 。
    var arrSh = ["Lily", "lucy", "Tom"];
    var countSh = arrSh.unshift("Jack", "Sean");
    console.log(countSh); // 5
    console.log(arrSh); //["Jack", "Sean", "Lily", "lucy", "Tom"]
    var newArrSh = ["Jack", "Sean", "Lily", "lucy", "Tom"]
    var itemSh = newArrSh.shift();
    console.log(itemSh); // Jack
    console.log(newArrSh); // ["Sean", "Lily", "lucy", "Tom"]

    // 4.sort():按升序排列数组项——即最小的值位于最前面,最大的值排在最后面。
    var arr1 = ["ad", "dg", "c", "b"];
    console.log(arr1.sort()); // ["ad", "b", "c", "dg"]
    arr2 = [13, 24, 51, 3];
    console.log(arr2.sort()); // [13, 24, 3, 51]
    console.log(arr2); // [13, 24, 3, 51](元数组被改变)
    // 排序
    function compare(val1, val2) {
      return val1 - val2
    }
    console.log(arr2.sort(compare)) //[3, 13, 24, 51]

    // 5.reverse():反转数组项的顺序。
    var arrNum = [13, 24, 51, 3];
    console.log(arrNum.reverse()); //[3, 51, 24, 13]
    console.log(arrNum); //[3, 51, 24, 13](原数组改变)

    // 6.concat()  原数组没有变
    var arrC = [1, 3, 5, 7];
    var arrCopy = arrC.concat(9, [11, 13]);
    console.log(arrCopy); //[1, 3, 5, 7, 9, 11, 13]
    console.log(arrC); // [1, 3, 5, 7](原数组未被修改)

    var arrCopy2 = arrC.concat([9, [11, 13]]);
    console.log(arrCopy2); //[1, 3, 5, 7, 9, Array[2]]
    console.log(arrCopy2[5]); //[11, 13]

    // 7.slice() (原数组没变)
    // slice():返回从原数组中指定开始下标到结束下标之间的项组成的新数组。slice()方法
    // 可以接受一或两个参数,即要返回项的起始和结束位置。
    // 在只有一个参数的情况下, slice()方法返回从该参数指定位置开始到当前数组末尾的所
    // 有项。如果有两个参数,该方法返回起始和结束位置之间的项——
    // 但不包括结束位置的项。
    var arr = [1, 3, 5, 7, 9, 11];
    var arrCopy = arr.slice(1);
    var arrCopy2 = arr.slice(1, 4);
    var arrCopy3 = arr.slice(1, -2);
    var arrCopy4 = arr.slice(-4, -1);
    console.log(arr); //[1, 3, 5, 7, 9, 11](原数组没变)
    console.log(arrCopy); //[3, 5, 7, 9, 11]
    console.log(arrCopy2); //[3, 5, 7]
    console.log(arrCopy3); //[3, 5, 7]
    console.log(arrCopy4); //[5, 7, 9]

    // 8.splice() (原数组改变了)
    // splice():很强大的数组方法,它有很多种用法,可以实现删除、插入和替换。
    // 删除: 可以删除任意数量的项, 只需指定 2 个参数: 要删除的第一项的位置
    // 和要删除的项数。 例如, splice(0, 2) 会删除数组中的前两项。
    // 插入: 可以向指定位置插入任意数量的项, 只需提供 3 个参数: 起始位置、 
    // 0( 要删除的项数) 和要插入的项。 例如, splice(2, 0, 4, 6)
    //  会从当前数组的位置 2 开始插入4和6。
    // 替换: 可以向指定位置插入任意数量的项, 且同时删除任意数量的项, 只需指
    // 定 3 个参数: 起始位置、 要删除的项数和要插入的任意数量的项。 
    // 插入的项数不必与删除的项数相等。 例如, splice(2, 1, 4, 6) 会删除当前
    // 数组位置 2 的项, 然后再从位置 2 开始插入4和6。
    // splice() 方法始终都会返回一个数组, 该数组中包含从原始数组中删除的项,
    //  如果没有删除任何项, 则返回一个空数组
    var arr = [1, 3, 5, 7, 9, 11];
    var arrRemoved = arr.splice(0, 2);
    console.log(arr); //[5, 7, 9, 11]
    console.log(arrRemoved); //[1, 3]
    var arrRemoved2 = arr.splice(2, 0, 4, 6);
    console.log(arr); // [5, 7, 4, 6, 9, 11]
    console.log(arrRemoved2); // []
    var arrRemoved3 = arr.splice(1, 1, 2, 4);
    console.log(arr); // [5, 2, 4, 4, 6, 9, 11]
    console.log(arrRemoved3); //[7]

    // 9、indexOf()和 lastIndexOf()
    // indexOf():接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中,
    //  从数组的开头(位置 0)开始向后查找。 
    // lastIndexOf:接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中,
    //  从数组的末尾开始向前查找。
    // 这两个方法都返回要查找的项在数组中的位置,或者在没找到的情况下返回1。在比较第一
    // 个参数与数组中的每一项时,会使用全等操作符。
    var arr = [1, 3, 5, 7, 7, 5, 3, 1];
    console.log(arr.indexOf(5)); //2
    console.log(arr.lastIndexOf(5)); //5
    console.log(arr.indexOf(5, 2)); //2
    console.log(arr.lastIndexOf(5, 4)); //2
    console.log(arr.indexOf("5")); //-1

    // 10.forEach():对数组进行遍历循环,对数组中的每一项运行给定函数。这个方法没有返回值。
    // 参数都是function类型,默认有传参,参数分别为:遍历的数组内容;第对应的数组索引,数组本身。
    var arr = [1, 2, 3, 4, 5];
    arr.forEach(function (x, index, a) {
      console.log(x + '|' + index + '|' + (a === arr));
    });
    // 输出为:
    // 1|0|true
    // 2|1|true
    // 3|2|true
    // 4|3|true
    // 5|4|true

    // 11.map():指“映射”,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
    var arr = [1, 2, 3, 4, 5];
    var arr2 = arr.map(function (item) {
      return item * item;
    });
    console.log(arr2); //[1, 4, 9, 16, 25]

    // 12.filter():“过滤”功能,数组中的每一项运行给定函数,返回满足过滤条件组成的数组。
    var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
    var arr2 = arr.filter(function (x, index) {
      return index % 3 === 0 || x >= 8; //index 是下标  x是每一项
    });
    console.log(arr2); //[1, 4, 7, 8, 9, 10]

    // 13.every():判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。
    var arr = [1, 2, 3, 4, 5];
    var arr2 = arr.every(function (x) {
      return x < 10;
    });
    console.log(arr2); //true
    var arr3 = arr.every(function (x) {
      return x < 3;
    });
    console.log(arr3); // false

    // 14.some():判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
    var arr = [1, 2, 3, 4, 5];
    var arr2 = arr.some(function (x) {
      return x < 3;
    });
    console.log(arr2); //true
    var arr3 = arr.some(function (x) {
      return x < 1;
    });
    console.log(arr3); // false

    // 15.reduce()和 reduceRight()
    // 这两个方法都会实现迭代数组的所有项,然后构建一个最终返回的值。reduce()方法从数组
    // 的第一项开始,逐个遍历到最后。而 reduceRight()则从数组的最后一项开始,向前遍历到第一项。
    // 这两个方法都接收两个参数:一个在每一项上调用的函数和(可选的)作为归并基础的初始值。
    // 传给 reduce()和 reduceRight()的函数接收 4 个参数:前一个值、当前值、项的索引和数组对象。
    // 这个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项上,因此
    // 第一个参数是数组的第一项,第二个参数就是数组的第二项。
    // 下面代码用reduce()实现数组求和,数组一开始加了一个初始值10。
    var values = [1, 2, 3, 4, 5];
    var sum = values.reduceRight(function (prev, cur, index, array) {
      return prev + cur;
    }, 10);
    console.log(sum); //25  1+2+3+4+5+10=25

    // 16.数组拷贝
    //方法1
    var a = [1, 2, 3];
    var b = a.slice();
    a.reverse;
    console.log(a); //[3,2,1]
    console.log(b); //[1,2,3]
    //方法2
    var c = [4, 5, 6];
    var d = c.concat();
    c.reverse();
    console.log(c); //[6,5,4]
    console.log(d); //[4,5,6]

    // 17.数组相等
    // 先说下坑吧: 
    // 任意两个数组相等都会返回false;[]=[];//false 
    // 怎么办?千万不要逐项去比较,看看上面可用的方法:toString(); 
    // 转化为字符串一次就比较完了。

관련 기사:

JS의 배열 작업 인스턴스

이러한 배열을 만드는 방법

관련 동영상:

JavaScript-javascript에서 배열 생성 및 작동 초보자용 비디오 튜토리얼

위 내용은 마스터해야 할 js에서 배열을 생성하는 방법에 대한 자세한 설명(순수 코드)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

C 및 JavaScript는 WebAssembly를 통한 상호 운용성을 달성합니다. 1) C 코드는 WebAssembly 모듈로 컴파일되어 컴퓨팅 전력을 향상시키기 위해 JavaScript 환경에 도입됩니다. 2) 게임 개발에서 C는 물리 엔진 및 그래픽 렌더링을 처리하며 JavaScript는 게임 로직 및 사용자 인터페이스를 담당합니다.

웹 사이트에서 앱으로 : 다양한 JavaScript 애플리케이션웹 사이트에서 앱으로 : 다양한 JavaScript 애플리케이션Apr 22, 2025 am 12:02 AM

JavaScript는 웹 사이트, 모바일 응용 프로그램, 데스크탑 응용 프로그램 및 서버 측 프로그래밍에서 널리 사용됩니다. 1) 웹 사이트 개발에서 JavaScript는 HTML 및 CSS와 함께 DOM을 운영하여 동적 효과를 달성하고 jQuery 및 React와 같은 프레임 워크를 지원합니다. 2) 반응 및 이온 성을 통해 JavaScript는 크로스 플랫폼 모바일 애플리케이션을 개발하는 데 사용됩니다. 3) 전자 프레임 워크를 사용하면 JavaScript가 데스크탑 애플리케이션을 구축 할 수 있습니다. 4) node.js는 JavaScript가 서버 측에서 실행되도록하고 동시 요청이 높은 높은 요청을 지원합니다.

Python vs. JavaScript : 사용 사례 및 응용 프로그램 비교Python vs. JavaScript : 사용 사례 및 응용 프로그램 비교Apr 21, 2025 am 12:01 AM

Python은 데이터 과학 및 자동화에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 데이터 처리 및 모델링을 위해 Numpy 및 Pandas와 같은 라이브러리를 사용하여 데이터 과학 및 기계 학습에서 잘 수행됩니다. 2. 파이썬은 간결하고 자동화 및 스크립팅이 효율적입니다. 3. JavaScript는 프론트 엔드 개발에 없어서는 안될 것이며 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축하는 데 사용됩니다. 4. JavaScript는 Node.js를 통해 백엔드 개발에 역할을하며 전체 스택 개발을 지원합니다.

JavaScript 통역사 및 컴파일러에서 C/C의 역할JavaScript 통역사 및 컴파일러에서 C/C의 역할Apr 20, 2025 am 12:01 AM

C와 C는 주로 통역사와 JIT 컴파일러를 구현하는 데 사용되는 JavaScript 엔진에서 중요한 역할을합니다. 1) C는 JavaScript 소스 코드를 구문 분석하고 추상 구문 트리를 생성하는 데 사용됩니다. 2) C는 바이트 코드 생성 및 실행을 담당합니다. 3) C는 JIT 컴파일러를 구현하고 런타임에 핫스팟 코드를 최적화하고 컴파일하며 JavaScript의 실행 효율을 크게 향상시킵니다.

자바 스크립트 행동 : 실제 예제 및 프로젝트자바 스크립트 행동 : 실제 예제 및 프로젝트Apr 19, 2025 am 12:13 AM

실제 세계에서 JavaScript의 응용 프로그램에는 프론트 엔드 및 백엔드 개발이 포함됩니다. 1) DOM 운영 및 이벤트 처리와 관련된 TODO 목록 응용 프로그램을 구축하여 프론트 엔드 애플리케이션을 표시합니다. 2) Node.js를 통해 RESTFULAPI를 구축하고 Express를 통해 백엔드 응용 프로그램을 시연하십시오.

JavaScript 및 웹 : 핵심 기능 및 사용 사례JavaScript 및 웹 : 핵심 기능 및 사용 사례Apr 18, 2025 am 12:19 AM

웹 개발에서 JavaScript의 주요 용도에는 클라이언트 상호 작용, 양식 검증 및 비동기 통신이 포함됩니다. 1) DOM 운영을 통한 동적 컨텐츠 업데이트 및 사용자 상호 작용; 2) 사용자가 사용자 경험을 향상시키기 위해 데이터를 제출하기 전에 클라이언트 확인이 수행됩니다. 3) 서버와의 진실한 통신은 Ajax 기술을 통해 달성됩니다.

JavaScript 엔진 이해 : 구현 세부 사항JavaScript 엔진 이해 : 구현 세부 사항Apr 17, 2025 am 12:05 AM

보다 효율적인 코드를 작성하고 성능 병목 현상 및 최적화 전략을 이해하는 데 도움이되기 때문에 JavaScript 엔진이 내부적으로 작동하는 방식을 이해하는 것은 개발자에게 중요합니다. 1) 엔진의 워크 플로에는 구문 분석, 컴파일 및 실행; 2) 실행 프로세스 중에 엔진은 인라인 캐시 및 숨겨진 클래스와 같은 동적 최적화를 수행합니다. 3) 모범 사례에는 글로벌 변수를 피하고 루프 최적화, Const 및 Lets 사용 및 과도한 폐쇄 사용을 피하는 것이 포함됩니다.

Python vs. JavaScript : 학습 곡선 및 사용 편의성Python vs. JavaScript : 학습 곡선 및 사용 편의성Apr 16, 2025 am 12:12 AM

Python은 부드러운 학습 곡선과 간결한 구문으로 초보자에게 더 적합합니다. JavaScript는 가파른 학습 곡선과 유연한 구문으로 프론트 엔드 개발에 적합합니다. 1. Python Syntax는 직관적이며 데이터 과학 및 백엔드 개발에 적합합니다. 2. JavaScript는 유연하며 프론트 엔드 및 서버 측 프로그래밍에서 널리 사용됩니다.

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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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