웹 프론트엔드 JS 튜토리얼 JavaScript 배열에 명명된 속성 추가: 객체 리터럴과 대괄호 표기법?

JavaScript 배열에 명명된 속성 추가: 객체 리터럴과 대괄호 표기법?

Nov 29, 2024 am 04:36 AM

Adding Named Properties to JavaScript Arrays: Object Literal vs. Bracket Notation?

배열에 명명된 속성 추가: JavaScript의 특이한 현상

JavaScript에서는 명명된 속성을 추가하는 기능을 포함하여 예상치 못한 방식으로 배열을 조작할 수 있습니다. 마치 객체인 것처럼 속성을 부여합니다. 이로 인해 질문이 제기됩니다. 대괄호를 사용하여 명명된 속성이 있는 배열을 선언하는 것과 객체 리터럴을 선언하는 것 사이에 근본적인 차이점이 있습니까?

짧은 대답은 다음과 같습니다. 예, 차이가 있습니다.

두 메소드 모두 표면적으로 유사하게 동작하고 typeof()로 검사할 때 '객체' 유형을 반환하지만 기본 특성이 다릅니다. 배열은 숫자로 인덱싱된 데이터용으로 설계된 반면, 객체는 숫자가 아닌 키용으로 설계되었습니다.

이러한 구분을 설명하려면 다음을 고려하세요.

var myArray = Array();
myArray['A'] = "Athens";
myArray['B'] = "Berlin";

alert(myArray.length);
로그인 후 복사

이 코드는 '0'을 표시합니다. 반면에 '2'가 표시될 것으로 예상할 수도 있습니다. 이는 배열에 추가된 명명된 속성이 해당 길이 속성에 영향을 주지 않기 때문입니다. 대신 배열 객체의 추가 속성으로 처리됩니다.

반대로 명명된 속성으로 선언된 객체 리터럴은 해당 길이를 올바르게 반영합니다.

var myObject = {'A': 'Athens', 'B': 'Berlin'};
alert(myObject.length); // This would display '2'
로그인 후 복사

따라서 가능하더라도 명명된 속성을 배열에 추가하는 것은 "남용"으로 간주되므로 피해야 합니다. 숫자가 아닌 키의 경우 대신 개체를 사용하는 것이 가장 좋습니다.

위 내용은 JavaScript 배열에 명명된 속성 추가: 객체 리터럴과 대괄호 표기법?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

JavaScript로 문자열 문자를 교체하십시오 JavaScript로 문자열 문자를 교체하십시오 Mar 11, 2025 am 12:07 AM

JavaScript로 문자열 문자를 교체하십시오

jQuery 날짜가 유효한지 확인하십시오 jQuery 날짜가 유효한지 확인하십시오 Mar 01, 2025 am 08:51 AM

jQuery 날짜가 유효한지 확인하십시오

jQuery는 요소 패딩/마진을 얻습니다 jQuery는 요소 패딩/마진을 얻습니다 Mar 01, 2025 am 08:53 AM

jQuery는 요소 패딩/마진을 얻습니다

10 JQuery Accordions 탭 10 JQuery Accordions 탭 Mar 01, 2025 am 01:34 AM

10 JQuery Accordions 탭

10 JQuery 플러그인을 확인할 가치가 있습니다 10 JQuery 플러그인을 확인할 가치가 있습니다 Mar 01, 2025 am 01:29 AM

10 JQuery 플러그인을 확인할 가치가 있습니다

노드 및 HTTP 콘솔로 HTTP 디버깅 노드 및 HTTP 콘솔로 HTTP 디버깅 Mar 01, 2025 am 01:37 AM

노드 및 HTTP 콘솔로 HTTP 디버깅

사용자 정의 Google 검색 API 설정 자습서 사용자 정의 Google 검색 API 설정 자습서 Mar 04, 2025 am 01:06 AM

사용자 정의 Google 검색 API 설정 자습서

jQuery div에 스크롤 바를 추가합니다 jQuery div에 스크롤 바를 추가합니다 Mar 01, 2025 am 01:30 AM

jQuery div에 스크롤 바를 추가합니다

See all articles