[javascript] 대괄호 Javascript 객체 키

누구든지 JavaScript에서 키를 할당하는 아래 방법이 어떻게 작동하는지 설명 할 수 있습니까?

a = "b"
c = {[a]: "d"}

반환:

Object {b: "d"}



답변

새로운 ES2015 (공식적으로 ES6로 알려진 EcmaScript 사양) 계산 된 속성 이름 구문 입니다. someObject[someKey]ES3 / 5에서 알고 있는 과제 의 속기입니다 .

var a = "b"
var c = {[a]: "d"}

다음에 대한 구문 설탕입니다.

var a = "b"
var c = {}
c[a] = "d"


답변

실제로의 사용은 JavaScript 객체 를 생성하는 동안 []변수의 실제 값을 /속성 으로 사용하는 훌륭한 방법을 제공 합니다 .

나는 위의 답변에 상당히 만족하고 있으며 약간의 예를 들어 이것을 작성할 수 있었기 때문에 감사합니다.

Node REPL (Node shell) 에서 코드를 한 줄씩 실행했습니다 .

> var key = "fullName";     // Assignment
undefined
>
> var obj = {key: "Rishikesh Agrawani"}    // Here key's value will not be used
undefined
> obj     // Inappropriate, which we don't want
{ key: 'Rishikesh Agrawani' }
>
> // Let's fix
undefined
> var obj2 = {[key]: "Rishikesh Agrawani"}
undefined
> obj2
{ fullName: 'Rishikesh Agrawani' }
>


답변

const animalSounds = {cat: 'meow', dog: 'bark'};

const animal = 'lion';

const sound = 'roar';

{...animalSounds, [animal]: sound};

결과는

{cat: 'meow', dog: 'bark', lion: 'roar'};


답변

또한 []평가 또는 런타임까지 그것이 무엇인지 아직 알지 못할 때 객체에 접근하거나 할당 하기 위해 표기법 을 사용하는 조건 만 있습니다 .


답변