> 웹 프론트엔드 > JS 튜토리얼 > 속성 접근자

속성 접근자

DDD
풀어 주다: 2024-10-26 05:45:31
원래의
1117명이 탐색했습니다.

Property accessors

JavaScript의 속성 접근자 이해

JavaScript에서 속성 접근자는 객체의 속성에 액세스할 수 있는 메커니즘입니다. 이를 수행하는 두 가지 주요 방법은 점 표기법과 대괄호 표기법입니다.

점 표기법

점 표기법은 속성에 액세스하는 가장 일반적인 방법입니다. 간단히 점(.) 뒤에 속성 이름을 사용하면 됩니다.

괄호 표기

대괄호 표기법은 속성 이름이 동적이거나 유효한 식별자가 아닌 경우(예: 공백이나 특수 문자가 포함된 경우) 유용합니다. 대괄호([])를 사용하고 속성 이름을 문자열로 전달합니다

JavaScript로 객체 생성

언어는 객체를 빠르게 생성하기 위해 객체 리터럴 표기법이라는 구문을 제공합니다. 객체 리터럴은 중괄호로 표시됩니다. 다음 예에서는 속성이 없는 빈 개체를 만듭니다.

var animal = {};

로그인 후 복사
로그인 후 복사
로그인 후 복사

중괄호 안에 속성과 해당 값은 키/값 쌍 목록으로 지정됩니다.
키는 문자열이나 식별자일 수 있고 값은 유효한 표현식일 수 있습니다. 키/값 쌍 목록은 쉼표로 구분되며 각 키와 값은 콜론으로 구분됩니다.

다음 예에서는 리터럴 표기법을 사용하여 세 가지 속성을 가진 객체를 생성합니다.

첫 번째 속성인 동물이 1위를 차지하고 있습니다.
두 번째 속성인 돌고래는 문자열을 사용하여 지정되며 문자열 값도 저장합니다. 세 번째 속성인 포유류는 빈 객체를 저장합니다.

var animal = {
  dolphin: 1,
  "swim": "some string",
  mammal: {
  }
};

로그인 후 복사
로그인 후 복사
로그인 후 복사

각 속성은 별도의 줄에 들여쓰기되어 작성되었습니다. 전체 객체를 한 줄에 작성할 수도 있지만 이 형식이 코드를 더 읽기 쉽습니다. 특히 속성이 많은 객체나 중첩된 객체의 경우 더욱 그렇습니다.

JavaScript는 객체 속성에 액세스하기 위한 두 가지 표기법을 제공합니다.

첫 번째이자 가장 일반적인 방법은 점 표기법입니다.
점 표기법에서는 호스트 개체의 이름, 마침표(또는 점), 속성 이름을 차례로 지정하여 속성에 액세스합니다.

점 표기법

점 표기법은 속성에 액세스하는 가장 일반적인 방법입니다. 간단히 점(.) 뒤에 속성 이름을 사용하면 됩니다. 예:

다음 예에서는 점 표기법을 사용하여 속성을 읽고 쓰는 방법을 보여줍니다. 만약 object.dolph
처음에는 값 1을 유지했지만 이 명령문을 실행한 후에는 값이 2가 됩니다.

  • animal.dolphon에 아직 값이 없으면 정의되지 않습니다.
var animal = {};

로그인 후 복사
로그인 후 복사
로그인 후 복사

객체 속성에 액세스하는 구문을 대괄호 표기법이라고 합니다. 괄호 표기에서는 개체 이름 뒤에 대괄호가 옵니다.
대괄호 안에는 속성 이름이 문자열으로 지정됩니다.
아래에서는 점 표기법의 이전 예를 대괄호 표기법을 사용하도록 다시 작성했습니다. 코드는 다르게 보일 수 있지만 기능적으로는 이전 예제와 동일합니다.

var animal = {
  dolphin: 1,
  "swim": "some string",
  mammal: {
  }
};

로그인 후 복사
로그인 후 복사
로그인 후 복사

대괄호 표기법변수가 속성 이름의 전부 또는 일부를 지정할 수 있도록하기 때문에 점 표기법보다 더 표현력이 좋습니다.
이는 자바스크립트 인터프리터가 자동으로 대괄호 안의 표현식을 문자열로 변환한 다음 해당 속성을 검색하기 때문에 가능합니다.

다음 예에서는 대괄호 표기법을 사용하여 속성 이름을 즉시 생성하는 방법을 보여줍니다. 예제에서 속성 이름 foo는 변수 d의 내용을 문자열 "dolphin"과 연결하여 생성됩니다.

animal.dolphin = animal.dolphin + 1;
로그인 후 복사
로그인 후 복사

대괄호 표기법을 사용하면 속성 이름에 점 표기법으로 금지된 문자를 포함할 수 있습니다.
예를 들어, 다음 명령문은 대괄호 표기법에 완전히 적합합니다. 하지만 동일한 속성 이름을 점 표기법으로 생성하려고 하면 구문 오류가 발생합니다.

object["dolphin"] = object["dolphin"] + 1;
로그인 후 복사
로그인 후 복사

중첩된 속성에 액세스

중첩된 개체의 속성은 점 및/또는 대괄호 참조를 함께 연결하여 액세스할 수 있습니다.
예를 들어, 다음 개체에는 돌고래라는 이름의 중첩 개체가 포함되어 있습니다. 여기에는 1이라는 값을 보유하는 연도라는 속성이 있는 포유류라는 또 다른 개체가 포함되어 있습니다.

var d = "d";

object[d + "dolphin"] = "bar";
로그인 후 복사

다음 표현식은 중첩 속성인 연도에 액세스합니다. 첫 번째 표현식은 점 표기를 사용하고, 두 번째 표현식은 대괄호 표기를 사용합니다.
세 번째 표현식은 두 표기법을 결합하여 동일한 결과를 얻습니다.

object["!@#$%^&*()."] = true;
로그인 후 복사

이전 예시와 같은 표현식을 잘못 사용하면 성능이 저하될 수 있습니다.
점 또는 괄호 표현을 평가하는 데는 시간이 걸립니다.

동일한 속성이 여러 번 사용되는 경우 속성에 한 번 액세스한 다음 나중에 사용할 수 있도록 값을 로컬 변수에 저장하는 것이 더 합리적입니다. 다음 예에서는 루프 내에서 bar를 여러 번 사용합니다. 그러나 동일한 값을 반복해서 계산하는 데 시간을 낭비하는 대신 bar는 지역 변수에 저장됩니다.

var animal = {};

로그인 후 복사
로그인 후 복사
로그인 후 복사

메소드로서의 기능

함수를 객체 속성으로 사용하는 것을 메소드라고 합니다. 속성과 마찬가지로 메서드도 객체 리터럴 표기법으로 지정할 수 있습니다. 다음 예는 이것이 어떻게 이루어지는지 보여줍니다.

var animal = {
  dolphin: 1,
  "swim": "some string",
  mammal: {
  }
};

로그인 후 복사
로그인 후 복사
로그인 후 복사

메소드점 및 괄호 표기법을 사용하여 호출할 수도 있습니다.
다음 예제에서는 두 표기법을 모두 사용하여 이전 예제의 sum() 메서드를 호출합니다.

animal.dolphin = animal.dolphin + 1;
로그인 후 복사
로그인 후 복사

속성 및 메서드 추가

객체 리터럴 표기법새 객체 생성에 유용하지만 기존 객체에 속성이나 메서드를 추가할 수는 없습니다.
다행히 객체에 새 데이터를 추가하는 것은 대입문을 만드는 것만큼 간단합니다.

다음 예에서는 빈 개체를 만듭니다.
그런 다음 할당 문을 사용하여 돌고래와 포유류라는 두 가지 속성과 메서드인 연도를 추가합니다.
이 예에서는 점 표기법을 사용하지만 괄호 표기법도 동일하게 작동합니다.

object["dolphin"] = object["dolphin"] + 1;
로그인 후 복사
로그인 후 복사

요약
객체는 기본 객체와 기타 객체로 구성된 복합 데이터 유형입니다. 개체의 빌딩 블록은 일반적으로 해당 필드 또는 속성이라고 합니다. 속성은 개체의 일부 측면을 설명하는 데 사용됩니다. 예를 들어 속성은 목록의 길이, 강아지의 색깔 또는 사람의 생년월일을 설명할 수 있습니다.
따라서 JavaScript 객체 구문은 언어의 기초 역할을 하므로 이해하는 것이 중요합니다.
객체 지향 프로그래밍을 이해하려면 먼저 객체를 이해해야 합니다.

  • 점 표기법: 속성 이름이 유효한 식별자인 경우 사용합니다.
  • 대괄호 표기법: 속성 이름이 동적이거나 유효한 식별자가 아닌 경우에 사용합니다. 이러한 접근자는 객체와 해당 속성을 효과적으로 조작하기 위한 JavaScript의 기본입니다.

즐거운 코딩하세요!

위 내용은 속성 접근자의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿