Javascript Objects 상세 설명
•대상 직접 량
var o = {
foo : "bar"
}
구조 함수
var o = new Object();
원형 계승
var p = Object.create(o);
상속
Javascript 대상 은 자체 속성 과 계승 속성 을 가지 고 있 습 니 다.
•대상 o 의 속성 x 를 조회 할 때 o 의 속성 x 를 먼저 찾 습 니 다. 찾 지 못 하면 o 의 원형 대상 중의 x 속성 을 찾 습 니 다. x 또는 원형 이 null 의 대상 일 때 까지 찾 습 니 다.
•대상 o 의 x 속성 할당 시 o 에 자체 속성 x 가 있 으 면 x 의 값 을 바 꿉 니 다. o 에 속성 x 가 존재 하지 않 으 면 o 에 x 속성 을 만 들 고 할당 합 니 다.
•검색 할 때 만 프로 토 타 입 체인 이 작용 한 다 는 것 이다.
var O = {
x : 1
};
function P() {
this.y = 2;
}
P.prototype = O;
var t = new P();
console.log(t);
console.log('x' in t);//true
console.log(t.hasOwnProperty('x'));//false
인 또는 hasOwnProperty 를 사용 하여 대상 에 속성 이 있 는 지 여 부 를 판단 할 수 있 습 니 다.
대상 속성
•대상 속성 옮 겨 다 니 기 대상 의 속성 을 for. in 으로 옮 겨 다 닐 수 있 습 니 다.
for. in 을 사용 할 때 원형 체인 에 있 는 속성 을 옮 겨 다 닙 니 다.옮 겨 다 니 는 순 서 는 넓 은 범위 로 우선 옮 겨 다 니 는 것 입 니 다.
그래서 hasOwnProperty 를 사용 하면 대상 자체 의 속성 여 부 를 판단 할 수 있 습 니 다.
•대상 속성의 특성 Object. getOwnProperty Descriptor () 를 사용 하여 대상 의 특정 속성 에 대한 설명 자 를 가 져 옵 니 다.
쓰기 가능 성 (writable) 은 대상 속성 을 쓸 수 있 는 지 여 부 를 표시 합 니 다.
예컨대
var o = {
foo : 'bar'
}
Object.defineProperty(o, "foo", { writable : false });
o.foo = 'world';
console.log(o.foo);// bar
매 거 성 (enumerable) 은 대상 속성 을 매 거 할 수 있 는 지 여 부 를 표시 합 니 다.
예컨대 Array 의 length 등 속성의 enumerable 은 false 이기 때문에...
for (p in Array) {
console.log(p);
}
아무것도 출력 하지 않 음
설정 가능 성 (configurable) 은 속성 을 변경 할 수 있 는 설정 성과 매 거 진 성 을 표시 합 니 다.
이 설정 속성 을 Object. define Properties 로 정의 할 수 있 습 니 다.Object.defineProperty(o, "foo", { writable : false });
Get 은 대상 속성 을 가 져 오 는 방법 Set 는 대상 속성 을 설정 하 는 방법 을 표시 합 니 다.
예시
var book = {
_year: 2004,
edition: 1
};
Object.defineProperty(book, "year", {
get: function () {
console.log('get year');
return this._year;
},
set: function (newValue) {
console.log('set year');
if (newValue > 2004) {
this._year = newValue;
this.edition += newValue - 2004;
}
}
});
book.year = 2005;// ‘set year'
console.log(book.year);// ‘get year' year
대상 방법
toString 은 대상 을 문자열 로 변환 합 니 다. 기본 변환 은 [object Object] 와 같은 것 이기 때문에 json 형식 으로 변환 하려 면 JSON. stringify 를 사용 할 수 있 습 니 다.
value Of 는 대상 을 다른 유형 으로 변환 할 때 사용 해 야 합 니 다.마찬가지 로 기본 변환 은 할 말 이 없다. 실행 가능 대상
다음 방법 을 통 해 실행 가능 한 대상 을 만 들 수 있 습 니 다.
function bar(o) {
var f = function() { return "Hello World!"; }
o.__proto__ = f.__proto__;
f.__proto__ = o;
return f;
}
var o = { x: 5 };
var foo = bar(o);
console.log(foo());
console.log(foo.x);
console.log(typeof foo);//function
대상 으로 사용 할 수도 있 고 함수 로 직접 호출 할 수도 있다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.