데이터 속성:
데이터 속성에는 값을 읽고 쓸 수 있는 데이터 값의 위치가 포함됩니다.
4가지 행동 특성 설명:
writable은 속성 값을 수정할 수 있는지 여부를 나타냅니다. 기본값은 true
Enumerable은 for in 루프를 통해 반환된 속성을 열거할 수 있는지 여부를 나타냅니다.
configuralbe는 속성을 삭제하고 재정의할 수 있는지 여부와 해당 구성을 수정할 수 있는지 여부를 나타냅니다.
value에는 이 속성의 데이터 값이 포함됩니다. 속성 값을 읽을 때 이 위치에서 읽으십시오.
속성 값을 작성할 때 이 위치에 새 값을 저장하세요. 이 기능의 기본값은 true입니다.
<script> function Foo(){} Foo.prototype.z = var obj = new Foo() obj.x = alert("x" in obj) //=>true x是obj对象的自有属性 alert("z" in obj) //=>true z是obj原型上继承来看属性 //hasOwnProperty 必须是对象上的自有的属性才返回true alert(obj.hasOwnProperty("x")) //true x是obj对象上的自有属性 alert(obj.hasOwnProperty("z")) //false z是obj原型上继承来的属性,不是他的私有属性 alert(Foo.prototype.hasOwnProperty("z")) //=>true z是原型上自有的属性,所以返回true alert(Object.prototype.hasOwnProperty("toString"))//=>toString 是顶级对象上的自有属性,所以返回true //prpertyisEnumeralbe 的意思是必是对象上的自有属性而且要以是枚举的,但是对象的可枚举属性Enumeralbe是true,才能返回true alert(obj.propertyIsEnumerable("x")) //true x是obj对象上可枚举的属性 alert(obj.propertyIsEnumerable("z")) //false z是obj原型上的属性,不是自有属性,则不可以枚举 alert(Foo.prototype.propertyIsEnumerable("z")) //true x是原型上的自有属性,所以可以枚举 </script>
속성을 어떻게 열거하나요? 열거된 속성과 프로토타입의 차이점은 무엇인가요?
데모 코드는 다음과 같습니다.
<script> function Foo(){} Foo.prototype.age = var obj = new Foo() obj.name = "ziksang" obj.addr = "上海" obj.telephone = for(var p in obj){ //使用FOR IN 可以枚举出自身的属性和原型上的属性 console.log(p) } console.log(Object.keys(obj)) //使用Object.keys(obj)只可以枚举Obj对象上自身的属性 console.log(Object.getOwnPropertyNames(obj)) //Object.getOwnPropertyNames(obj)是列出Ojb对象上自身的属性名,与枚举不相关,但是又类似枚举,大家要注意区分 </script>
위 내용은 편집자가 소개한 JavaScript의 연관된 프로토타입 체인 속성 특성에 대한 지식입니다.