웹 프론트엔드 JS 튜토리얼 js 1차원 배열, 다차원 배열 및 object_javascript 기술의 혼합 사용

js 1차원 배열, 다차원 배열 및 object_javascript 기술의 혼합 사용

May 16, 2016 pm 03:06 PM
1차원 배열 다차원 배열

이 글의 주요 목적은 JavaScript 배열과 객체의 혼합 사용을 설명하는 것입니다. JS의 약한 검사 특성으로 인해 다양한 유형의 변수가 JS 배열에 동시에 저장될 수 있습니다. 상점 번호, 문자열, 문자, 객체 및 기타 콘텐츠가 동일한 배열에 배치됩니다. 객체도 동일한 작업을 수행할 수 있습니다. 차이점은 객체가 객체의 각 멤버에 대한 별칭을 지정할 수 있으므로 프로그래밍 중에 데이터를 더 쉽게 읽을 수 있다는 것입니다.

var arr1 = ["飞鱼", 25, 172, "江苏"];
var person = {name:"飞鱼",age: 25, height:172,province: "江苏"};
로그인 후 복사

이렇게 하면 person.name이 arr1[0]보다 읽고 사용하기 더 쉽나요? 물론 배열과 객체에는 각각의 장점이 있습니다. 이 글에서는 두 가지 장점을 결합하여 포괄적으로 사용하는 데 중점을 둡니다.

1차원 배열
다음 코드는 cars라는 배열을 만듭니다. 먼저 배열을 만든 다음 값을 하나씩 할당합니다.

var cars=new Array();
cars[0]="Audi";
cars[1]="BMW";
cars[2]="Volvo";
로그인 후 복사

또는 (축소된 배열): 배열 객체 생성 시 값 할당

코드 복사 코드는 다음과 같습니다.

var cars=new Array("Audi","BMW","Volvo");

또는 (리터럴 배열): 변수를 만들지 말고 직접 보조하되, 객체를 생성할 때 사용하는 괄호 "( )"와 값을 직접 할당할 때 사용하는 대괄호 "[ ]"에 주의하세요. 조심하지 않으면 오류가 발생합니다.
예시
코드 복사 코드는 다음과 같습니다.

var cars=["아우디","BMW","볼보"];

위에는 1차원 배열을 만드는 세 가지 방법이 있습니다. JS의 약한 검사 특성으로 인해 다양한 유형의 변수를 1차원 배열에 넣을 수 있습니다.

2차원 및 다차원 배열:
1. 2차원 배열 생성 방법 1: 먼저 1차원 배열을 생성한 후, 1차원 배열의 모든 구성원에 대한 1차원 데이터를 생성합니다

var persons = new Array();

persons[0] = new Array();
persons[1] = new Array();
persons[2] = new Array();

persons[0][0] = "zhangsan";
persons[0][1] = 25;
persons[1][0] = "lisi";
persons[1][1] = 22;
persons[2][0] = "wangwu";
persons[2][1] = 32;
persons[0] = ["zhangsan", 25];
persons[1] = ["lisi", 21];
persons[2] = ["wangwu", 32];
로그인 후 복사

이전 방법에 비해 이 방법이 훨씬 간단하고 읽기 쉽습니다.

코드 복사 코드는 다음과 같습니다.

명.길이 = 3

​ ​ 2. 2차원 배열 생성 방법 2 : 먼저 1차원 배열을 생성한 후 1차원 배열의 모든 멤버에 직접 값을 할당
코드 복사 코드는 다음과 같습니다.

var people = new Array();

3. 2차원 배열 생성 방법 3: 직접 할당
코드 복사 코드는 다음과 같습니다.

var 명 = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];

4. 요약
첫 번째와 두 번째 방법이 더 번거롭기는 하지만 먼저 빈 다차원 배열을 만든 다음 for 루프에서 필요에 따라 값을 할당할 수 있습니다. 세 번째 방법은 열거된 데이터에 대해 상대적으로 간단하고 사용하기 쉽습니다.
2차원 배열에 대한 마지막 질문은 2차원 또는 다차원 배열의 길이는 얼마입니까? 다음 코드를 테스트해 보겠습니다.

코드 복사 코드는 다음과 같습니다.

document.write("persons = " + 명 + "
persons.length = " + people.length);

출력 결과는 다음과 같습니다.
           명 = zhangsan,25,lisi,21,wangwu,32
즉, 다차원 배열의 length 속성은 다차원 배열의 요소 수가 아닌 다차원 배열의 첫 번째 차원의 길이를 반환합니다.

5. 다차원 배열의 요소 개수를 반환하는 방법

다음 배열:

코드 복사 코드는 다음과 같습니다.

var 명 = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];

通过维数(此处是3)乘以每维元素的个数(此处是2)就可以得出该多维数组的元素个数是6了。但是这并不是保险的做法,因为多维数组中每一个维度的元素个数是可以不一样的,如:

复制代码 代码如下:

var persons = [["zhangsan", 25], ["lisi", 21, 172], ["wangwu", 32]];

该数组的第一维的第二个元素数组包含三个元素,其他的只有两个,这再使用length来计算还是3,因为第一维的元素个数没变嘛。但是再使用上面的方法计算该多维数组的元素个数就不对了。
因此多维数组的length属性和一维数组一样,永远返回第一维数组的元素个数。计算多维数组的元素个数,可以自己创建一个或多个嵌套for循环来计算,如:
在知道数组的维度的情况下,可以针对该数组写算法,如二维数组:

var persons = [["zhangsan", 25], ["lisi", 21], ["wangwu", 32]];
function getArr2ElementNum(arr) {
var eleNum = 0;
if (arr == null) {
return 0;
}
for (var i = 0; i < arr.length; i++) {
for (var j = 0; j < arr[i].length; j++) {
eleNum++;
}
}
return eleNum;
}
alert(getArr2ElementNum(persons));
로그인 후 복사


在多维数组维度过多,嵌套复杂时,通过上面的方法来写针对的算法就太累了,特别是当这个复杂的多维数组还可能随时变换维度的情况下。如下这个复杂的多重嵌套的多维数组:
var arrN = [["zhangsan", 25, [1, "wangyuchu", 54, [123, 34, 16]], 43], ["lisi", 21, 172], ["wangwu", 32, "suzhou"]];
甚至,有些多维嵌套数组比这个还复杂,那怎么计算数组元素个数呢,我写了一个求数组元素个数的函数,不管是一维还多维,也不管是多么复杂的嵌套多维数组,都可以计算出来,算法不麻烦,主要用到了递归的理念:
//判断某个对象是不是数组

function isArray(obj) {
return obj && ( typeof obj === 'object') && (obj.constructor == Array);
}

//eleNum变量初始值为0,用来统计数组元素个数
var eleNum = 0;

//递归计算某个数组元素是不是下一维数组,如果是,则继续递归下去;如果不是,统计元素个数。
function recursion(obj) {
if (isArray(obj)) {
for (var j = 0; j < obj.length; j++) {
if (!isArray(obj[j])) {
eleNum++;
continue;
}
recursion(obj[j]);
}
} else {
eleNum++;
}
}

//arr为要计算数组元素个数的一维或多维数组,通过调用递归函数recursion返回数组元素个数
function getArrNElementNum(arr) {
if (arr == null) {
return 0;
}

recursion(arr);

return eleNum;
}

//随意定义一个复杂的多维嵌套数组
var arrN = [["zhangsan", 25, [1, "wangyuchu", 54, [123, 34, 16]], 43], ["lisi", 21, 172], ["wangwu", 32, "suzhou"]];
//打印出来数组元素个数
alert(getArrNElementNum(arrN));
로그인 후 복사

对象:
对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义。属性由逗号分隔:

复制代码 代码如下:

var person={firstname:"Bill", lastname:"Gates", id:5566};

上面例子中的对象 (person) 有三个属性:firstname、lastname 以及 id。
空格和折行无关紧要。声明可横跨多行:

var person={
firstname : "Bill",
lastname : "Gates",
id    : 5566
};
로그인 후 복사

对象属性有两种寻址方式:
实例

name=person.lastname;
name=person["lastname"];
로그인 후 복사

对象和多维数组的混合使用:
         想象这么一个场景,要枚举并统计清华大学(qinghua)、北京大学(beida)、浙江大学(zheda)三所大学一共有多少个系,怎么做?
         首先,建立一个数组,数组中包括着三所学校:

复制代码 代码如下:

var departments = [qinghua, beida, zheda];

        每个学校又有很多不同或相同的学院(xx),如何表示?在这里就要用到数组包含对象了:
复制代码 代码如下:

var departments = [qinghua{xx1, xx2, xx3}, beida{xx4, xx5,
 xx6, xx7}, zheda{xx8, xx9}];

每个学院又有不同的系(d),如何表示?
复制代码 代码如下:

var departments = [qinghua{xx1:[d1, d2], xx2[d3, d5],
 xx3:[d7, d8]}, beida{xx4, xx5, xx6, xx7}, zheda{xx8,
 xx9}];
 //只是举个例子,后面两个大学我就不表示了

上述例子就是一个数组,该数组的元素是学校对象,学校对象有N个学院属性,而每个学院属性又是一个包含多个系的数组,这就是一个典型的多维数组和对象混合使用的例子,可以简单明了的说明和列表学校、学院和系之间的级别、归属和数量关系。
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP 다차원 배열 정렬의 차원 여행: 1차원에서 다차원으로 PHP 다차원 배열 정렬의 차원 여행: 1차원에서 다차원으로 Apr 29, 2024 pm 09:09 PM

1차원 배열은 sort() 함수를 사용하여 정렬하고, 2차원 배열은 usort() 함수를 사용하여 내부 요소별로 정렬하며, 고차원 배열은 다층 중첩 usort() 함수를 사용하여 계층적 요소별로 정렬합니다. 분해 문제를 레이어별로 해결하는 것이 핵심입니다.

다차원 배열을 사용하여 두 행렬을 곱하는 Python 프로그램 다차원 배열을 사용하여 두 행렬을 곱하는 Python 프로그램 Sep 11, 2023 pm 05:09 PM

행렬은 행과 열로 배열된 숫자의 집합입니다. m행과 n열로 구성된 행렬을 mXn 행렬이라고 하며, m과 n을 차원이라고 합니다. 행렬은 목록이나 NumPy 배열을 사용하여 Python에서 만든 2차원 배열입니다. 일반적으로 행렬 곱셈은 첫 번째 행렬의 행과 두 번째 행렬의 열을 곱하여 수행할 수 있습니다. 여기서 첫 번째 행렬의 열 개수는 두 번째 행렬의 행 개수와 같아야 합니다. 입력 및 출력 시나리오 두 개의 행렬 A와 B가 있다고 가정합니다. 이 두 행렬의 차원은 각각 2X3과 3X2입니다. 곱셈 후 결과 행렬은 2개의 행과 1개의 열을 갖게 됩니다. [b1,b2][a1,a2,a3]*[b3,b4]=[a1*b1+a2*b2+a3*a3][a4,a5,a6][b5,b6][a4*b2+a

PHP에서 여러 배열을 하나의 다차원 배열로 결합하는 방법 PHP에서 여러 배열을 하나의 다차원 배열로 결합하는 방법 Jul 09, 2023 pm 01:08 PM

PHP에서 여러 배열을 다차원 배열로 병합하는 방법 PHP 개발에서 여러 배열을 다차원 배열로 병합해야 하는 경우가 종종 있습니다. 이 작업은 대규모 데이터 컬렉션을 운영할 때 매우 유용하며 데이터를 더 잘 구성하고 처리하는 데 도움이 될 수 있습니다. 이 문서에서는 이 작업을 수행하는 몇 가지 일반적인 방법을 소개하고 참조용 코드 예제를 첨부합니다. 방법 1: array_merge 함수를 사용합니다. array_merge 함수는 PHP에서 일반적으로 사용되는 배열 병합 함수입니다. 여러 배열을 병합할 수 있습니다.

PHP에서 array_walk_recursive 함수를 사용하여 다차원 배열에 대한 재귀 작업을 수행하는 방법 PHP에서 array_walk_recursive 함수를 사용하여 다차원 배열에 대한 재귀 작업을 수행하는 방법 Jun 26, 2023 am 11:40 AM

배열은 PHP에서 매우 일반적인 데이터 유형입니다. 때때로 다차원 배열과 관련된 상황에 직면하게 됩니다. 이 경우 모든 요소에 대해 동일한 작업을 수행해야 하는 경우 array_walk_recursive() 함수를 사용할 수 있습니다. array_walk_recursive() 함수는 다차원 배열에 대한 재귀 작업을 수행하는 데 도움이 되는 PHP의 매우 강력한 재귀 함수입니다. 다차원 배열의 각 요소를 재귀적으로 순회하고 그에 상응하는 작업을 수행할 수 있습니다.

2차원 PHP 배열을 1차원 배열로 변환하는 방법 2차원 PHP 배열을 1차원 배열로 변환하는 방법 Aug 03, 2023 am 11:14 AM

PHP 배열을 2차원에서 1차원 배열로 변환하는 방법: 1. 루프 순회를 사용하여 2차원 배열을 탐색하고 각 요소를 1차원 배열에 추가합니다. 2. "array_merge" 함수를 사용하여 여러 항목을 병합합니다. 2차원 배열을 "array_merge" 함수에 매개변수로 전달하여 1차원 배열로 변환합니다. 3. "array_reduce" 함수를 사용하면 배열의 모든 값을 처리할 수 있습니다. 콜백 함수를 통해 최종적으로 결과를 반환합니다.

다차원 PHP 배열을 역전시키는 효율적인 방법 다차원 PHP 배열을 역전시키는 효율적인 방법 Apr 29, 2024 am 09:00 AM

다차원 PHP 배열을 역전시키는 두 가지 효과적인 방법: array_reverse() 함수를 재귀적으로 사용: 각 중첩 배열의 요소를 재귀적으로 역전시킵니다. PHP7의 array_reverse() 함수: array_reverse() 함수의 새로운 오버로드를 사용하여 다차원 배열을 뒤집습니다.

PHP에서 다차원 배열을 정렬하는 방법 PHP에서 다차원 배열을 정렬하는 방법 Jul 07, 2023 pm 12:45 PM

PHP에서 다차원 배열을 정렬하는 방법 PHP에서 배열은 매우 일반적이고 중요한 데이터 구조이며 다차원 배열은 일부 복잡한 데이터 처리에서 더 자주 사용됩니다. 그러나 다차원 배열을 정렬하는 것은 까다로울 수 있습니다. 이 기사에서는 PHP에서 다차원 배열을 정렬하는 방법과 구체적인 코드 예제를 제공합니다. 시작하기 전에 먼저 다차원 배열의 구조를 이해해 봅시다. 다차원 배열은 배열의 요소가 중첩된 구조를 형성하는 배열이기도 함을 의미합니다. 예: $st

PHP 배열에 대한 심층 토론: 다차원 배열, 연관 배열 등에 대한 포괄적인 분석 PHP 배열에 대한 심층 토론: 다차원 배열, 연관 배열 등에 대한 포괄적인 분석 Mar 13, 2024 pm 02:36 PM

PHP 배열에 대한 심층적인 논의: 다차원 배열, 연관 배열 등에 대한 포괄적인 분석. PHP에서 배열은 여러 데이터 항목을 저장하고 인덱스를 통해 액세스할 수 있는 매우 중요한 데이터 구조입니다. PHP에서 배열은 인덱스 배열, 연관 배열, 다차원 배열 등 다양한 유형으로 나눌 수 있습니다. 각 유형에는 고유한 용도와 특성이 있습니다. 이 기사에서는 배열을 선언하고, 액세스하고, 순회하고, 작동하는 방법을 포함하여 다양한 유형의 PHP 배열을 자세히 살펴보고 독자의 이해를 돕기 위해 구체적인 코드 예제를 제공합니다. 1. 인덱스 배열 인덱스 번호

See all articles