찾다
웹 프론트엔드JS 튜토리얼js 배열의 기본 동작(모두 직접 정리)_javascript 기술

저는 오랫동안 js를 사용해왔지만 js의 배열 형태에 대해 공부한 적은 없습니다. 때로는 간단한 string.split(char)을 사용하세요. 제가 이 기간 동안 진행한 프로젝트는 배열을 여러 곳에 사용했습니다. JS의 달인이라고 생각했는데 시작하지 못했어요. 헤헤. 배우고 나니 js 배열이 VB나 C#보다 훨씬 더 강력하다는 것을 깨달았습니다.

1. 배열 생성

var arrayObj = new Array(); //创建一个数组
var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度
var arrayObj = new Array([element0[, element1[, ...[, elementN]]]]); //创建一个数组并赋值

두 번째 방법은 배열을 생성하고 길이를 지정하지만 실제로 배열은 모든 경우에 가변 길이이므로 길이가 5로 지정되더라도 요소는 여전히 유지될 수 있습니다. 지정된 길이로 저장됩니다. 그렇지 않으면 길이가 그에 따라 변경됩니다.

2. 배열 요소에 액세스

var testGetArrValue=arrayObj[1]; //배열의 요소 값을 가져옵니다
arrayObj[1]= "새 값입니다."; //배열 요소에 새 값 할당

3. 배열 요소 추가

코드

arrayObj. push([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组结尾,并返回数组新长度
arrayObj.unshift([item1 [item2 [. . . [itemN ]]]]);// 将一个或多个新元素添加到数组开始,数组中的元素自动后移,返回数组新长度
arrayObj.splice(insertPos,0,[item1[, item2[, . . . [,itemN]]]]);//将一个或多个新元素插入到数组的指定位置,插入位置的元素自动后移,返回""。

4. 배열 요소 삭제

arrayObj.pop(); //移除最后一个元素并返回该元素值
arrayObj.shift(); //移除最前一个元素并返回该元素值,数组中元素自动前移
arrayObj.splice(deletePos,deleteCount); //删除从指定位置deletePos开始的指定数量deleteCount的元素,数组形式返回所移除的元素

5. 배열 가로채기 및 병합

arrayObj.slice(start, [end]); //배열의 일부를 배열 형태로 반환합니다. end에 해당하는 요소는 포함되지 않습니다. 복사하세요
arrayObj.concat([item1[, item2[, . . . [,itemN]]]]); //여러 배열(문자열 또는 배열과 문자열의 혼합일 수도 있음)을 하나의 배열로 연결하고 새로 연결된 배열을 반환합니다. 배열

6. 어레이 사본

arrayObj.slice(0); //배열의 복사본 배열을 반환합니다.
을 가리키는 것이 아니라 새 배열입니다. arrayObj.concat(); //배열의 복사본 배열을 반환합니다. 이는
을 가리키는 것이 아니라 새 배열입니다.
7. 배열 요소 정렬

arrayObj.reverse(); //요소를 역순으로(첫 번째에서 마지막으로, 마지막에서 앞으로) 배열 주소를 반환합니다.
arrayObj.sort(); // 배열 요소를 정렬하고 배열 주소를 반환합니다

8. 배열 요소의 문자열화

arrayObj.join(separator); //배열의 각 요소 값을 구분 기호로 구분하여 연결하는 문자열을 반환합니다.
toLocaleString, toString, valueOf: 일반적으로 사용되지 않는 조인의 특수 용도로 간주될 수 있음

2. 배열 객체의 세 가지 속성

1. 속성

Length 속성은 배열의 길이, 즉 배열의 요소 수를 나타냅니다. 배열의 인덱스는 항상 0부터 시작하므로 배열의 상한과 하한은 각각 0과 길이-1입니다. 대부분의 다른 언어와 달리 JavaScript 배열의 길이 속성은 가변적이므로 특별한 주의가 필요합니다. 길이 속성이 더 크게 설정되면 전체 배열의 상태는 실제로 변경되지 않고 길이 속성만 더 커집니다. 길이 속성이 원본보다 작게 설정되면 원본 배열의 요소는 다음보다 크거나 같습니다. 길이는 모든 값을 잃게 됩니다. 다음은 길이 속성을 변경하는 방법을 보여주는 예입니다.

코드

var arr=[12,23,5,3,25,98,76,54,56,76];
//定义了一个包含10个数字的数组
alert(arr.length); //显示数组的长度10
arr.length=12; //增大数组的长度
alert(arr.length); //显示数组的长度已经变为12
alert(arr[8]); //显示第9个元素的值,为56
arr.length=5; //将数组的长度减少到5,索引等于或超过5的元素被丢弃
alert(arr[8]); //显示第9个元素已经变为"undefined"
arr.length=10; //将数组长度恢复为10
alert(arr[8]); //虽然长度被恢复为10,但第9个元素却无法收回,显示"undefined"

위 코드에서 길이 속성의 특성을 명확하게 볼 수 있습니다. 그러나 길이 객체는 명시적으로 설정할 수 있을 뿐만 아니라 암시적으로 수정할 수도 있습니다. JavaScript에서는 선언되지 않은 변수를 사용할 수 있습니다. 마찬가지로 정의되지 않은 배열 요소(길이보다 크거나 같은 인덱스를 갖는 요소 참조)를 사용할 수도 있습니다. 사용된 요소 인덱스의 값에 1을 더합니다. 예를 들어 다음 코드는 다음과 같습니다.

var arr=[12,23,5,3,25,98,76,54,56,76];
alert(arr.length);
arr[15]=34;
alert(arr.length);

또한 코드는 먼저 10개의 숫자를 포함하는 배열을 정의합니다. 경고 문에서 길이가 10임을 알 수 있습니다. 그런 다음 인덱스 15의 요소를 사용하여 15의 값, 즉 arr[15]=34를 할당합니다. 이때 경고 문을 사용하여 배열의 길이를 출력하며 결과는 16입니다. 그럼에도 불구하고 이는 강력한 형식의 프로그래밍에 익숙한 개발자에게는 놀라운 기능입니다. 실제로 new Array()를 사용하여 생성된 배열의 초기 길이는 0입니다. 배열의 길이가 변경되는 것은 정의되지 않은 요소의 연산입니다.
위의 소개에서 볼 수 있듯이 길이 속성은 배열의 용량을 쉽게 늘리거나 줄이는 데 사용할 수 있습니다. 따라서 길이 속성에 대한 심층적인 이해는 개발 과정에서 이를 유연하게 사용하는 데 도움이 될 것입니다.

2. 프로토타입 속성

객체 유형의 프로토타입에 대한 참조를 반환합니다. 프로토타입 속성은 객체에 공통됩니다.
objectName.prototype
objectName 매개변수는 객체 객체의 이름입니다.

설명:
프로토타입 속성을 사용하여 객체 클래스에 대한 기본 기능 세트를 제공합니다. 객체의 새로운 인스턴스는 객체의 프로토타입에 할당된 작업을 "상속"합니다.
배열 객체의 경우 다음 예에서는 프로토타입 특성의 사용을 보여줍니다.
배열의 최대 요소 값을 반환하는 배열 개체에 메서드를 추가합니다. 이를 수행하려면 함수를 선언하고 Array.prototype에 추가한 후 사용하세요.

코드

function array_max()
{
var i,
max = this[0];
for (i = 1; i < this.length; i++)
{
if (max < this[i])
max = this[i];
}
return max;
}
Array.prototype.max = array_max;
var x = new Array(1, 2, 3, 4, 5, 6);
var y = x.max();

이 코드가 실행된 후 y는 배열 x의 최대값, 즉 6을 보유합니다.

3. 생성자 속성

은 객체를 생성하는 함수를 나타냅니다.
object.constructor //object는 객체 또는 함수의 이름입니다.
설명: 생성자 속성은 프로토타입이 있는 모든 개체의 구성원입니다. 여기에는 Global 및 Math 개체를 제외한 모든 JScript 기본 개체가 포함됩니다. 생성자 속성은 특정 객체 인스턴스를 생성하는 함수에 대한 참조를 보유합니다.
예:
x = new String("안녕하세요");
if (x.constructor == String) // 프로세스(조건이 true).

또는
함수 MyFunc {
// 함수 본문.
}

y = 새로운 MyFunc;
if (y.constructor == MyFunc) // 프로세스(조건이 true).

배열의 경우:
y = 새로운 배열();

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP8.0中数组的合并操作:array_mergePHP8.0中数组的合并操作:array_mergeMay 14, 2023 am 08:52 AM

在PHP8.0版本中,数组合并操作是经过了改进的。这个改进主要针对的是数组数据类型的合并操作。在之前的版本中,PHP提供的数组合并操作是使用“+”符号实现的。但是,这种方法存在一些问题。如果两个数组中包含相同的键,那么第二个数组的键值将会覆盖第一个数组中的键值,如果需要把两个数组合并在一起,那么就需要技巧地使用array_merge()函数了。现在,在PHP

如何在PHP中将字符串放入数组,并按换行符拆分如何在PHP中将字符串放入数组,并按换行符拆分Aug 28, 2023 pm 10:57 PM

什么是PHP?PHP代表超文本预处理器,是一种用于Web开发的流行服务器端脚本语言。它旨在创建动态和交互式网页。PHP嵌入在HTML代码中并在服务器上执行,生成发送到客户端浏览器的HTML输出。凭借其简单易学的语法,PHP允许开发人员构建动态网站、处理表单数据、与数据库交互以及执行各种服务器端任务。它拥有庞大的库和框架生态系统,可增强其功能并使开发人员能够创建强大且可扩展的Web应用程序。PHP受到托管提供商的广泛支持,使其成为Web开发项目的首选。如何在PHP中将字符串放入数组并按换行符分割方

使用PHP进行数组操作的最佳实践使用PHP进行数组操作的最佳实践Jun 06, 2023 am 10:30 AM

PHP是一种广泛使用的服务器端脚本语言,可以通过许多不同的方式进行数组操作。本文将介绍我们编写PHP代码时的最佳实践,帮助您创建更高效、更美观、更可读的代码。1.使用数组函数而不是手动循环最好使用PHP数组函数,而不是手动循环数组来移动、操作或修改数据。PHP数组函数执行较快,具有更好的可读性和可维护性。下面是一些常用的PHP数组函数:array_push(

PHP8.0中数组中的危险操作:array_splice()PHP8.0中数组中的危险操作:array_splice()May 14, 2023 am 08:24 AM

PHP8.0中数组中的危险操作:array_splice()在PHP编程中,数组是一个非常常用的数据结构,它允许我们在一个变量中存储多个值。而array_splice()函数则是一个处理数组的方法,它可以删除或替换数组中的元素。但是,在PHP8.0中,array_splice()函数却有一些危险操作,如果使用不当,将会导致一些严重的问题。本文将为大家详细介绍

使用PHP自定义函数扩展数组交集和并集的功能使用PHP自定义函数扩展数组交集和并集的功能May 01, 2024 am 10:45 AM

使用PHP自定义函数可扩展数组交集和并集功能,自定义交集函数允许按键或值查找交集,而自定义并集函数按键或值查找并集。这使您能够基于特定需求灵活操作数组。

PHP数组操作大全:array_diff()PHP数组操作大全:array_diff()Jun 20, 2023 pm 03:57 PM

在PHP中,数组是一种非常常见和有用的数据结构。PHP提供了许多不同的函数和方法来操作和处理这些数组。其中一个非常有用的函数是array_diff()。本文将详细讨论此函数。array_diff()函数的基本用法非常简单。该函数接受两个或多个数组作为参数,并返回一个新数组,其中包含第一个数组中存在,但其他数组中不存在的元素。下面是一个示例:$array1=

PHP 数组键值互换:性能对比及最优方案详解PHP 数组键值互换:性能对比及最优方案详解May 04, 2024 pm 01:51 PM

PHP数组键值互换的最佳方案:使用内置的array_flip()函数,时间复杂度为O(n)。对于较大的数组,array_flip()的性能优势更明显。实战案例:可使用array_flip()将购物车中商品名称数组转换为商品数量数组。

PHP 数组如何添加和删除元素PHP 数组如何添加和删除元素Sep 05, 2023 pm 02:12 PM

PHP数组如何添加和删除元素在PHP中,数组是一种非常常见且重要的数据结构。数组可以容纳多个值,并且能够根据需要动态增加或减少元素。本文将介绍如何在PHP中添加和删除数组元素,并提供相应的代码示例。一、添加元素使用方括号[]语法添加元素最简单的方法是使用方括号[]语法。示例如下:$arr=[&quot;apple&quot;,&quo

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 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전