이 글에서는 javascript에 대한 관련 지식을 소개합니다. 속성 설명자, 데이터 설명자, 액세스 설명자 등 객체지향과 관련된 문제를 주로 소개합니다. 모두에게 도움이 되기를 바랍니다.
【관련 권장 사항: javascript 비디오 튜토리얼, web front-end】
JavaScript는 실제로 함수형 프로그래밍과 객체 지향 프로그래밍을 포함한 다양한 프로그래밍 패러다임을 지원합니다. :
var obj = new Object() obj.name = 'why' console.log(obj.name, obj) // why { name: 'why' }
// 字面量方式 var obj2 = { name: 'jam', age: '8' } console.log(obj) // { name: 'jam', age: '8' }
이전에는 객체 내부에서 속성을 직접 정의하거나 객체에 직접 추가했습니다.
그러나 이런 방식으로 이 속성에 일부 제한을 적용할 수 없습니다. 예를 들어 delect
를 통해 이 속성을 삭제할 수 있고 for-in 중에 탐색할 수 있습니다.
순회? delect
删除,是否可以在 for-in
遍历的时候被遍历出来呢?
如果我们想要对一个属性进行比较精准的操作控制,那么我就可以使用 属性描述符。通过属性描述符可以精准的添加或修改对象的属性;
属性描述符需要使用 Object.defineProperty
来对属性进行添加或修改。
属性描述符分为两种:数据描述符和存取描述符
数据描述符是一个具有值的属性,该值可能是可写的,也可能是不可写的。数据描述符具有以下可选键值:
Object.getOwnPropertyDescriptor()方法返回指定对象上一个自有属性对应的属性描述符。
Object.getOwnPropertyDescriptor(obj,prop)
注意:如果该方法的第一个参数不是对象,会报错(TypeError)。
Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象。
Object.defineProperty(obj,prop,descriptor)
如下示例代码展示了属性描述符的设置和获取 var obj = { name: 'jam', age: 8 } Object.defineProperty(obj, 'job', { value: '律师' }) console.log(Object.getOwnPropertyDescriptor(obj, 'age')) // { value: 8, writable: true, enumerable: true, configurable: true } console.log(obj.job) // 律师 // 通过defineProperty新增的属性,该新属性是不可修改、不可删除以及不可枚举的 console.log(Object.getOwnPropertyDescriptor(obj, 'job')) // {value: '律师',writable: false,enumerable: false,configurable: false}
를 사용할 수 있습니다. 개체의 속성은 속성 설명자를 통해 정확하게 추가하거나 수정할 수 있습니다.속성 설명자
注意:通过defineProperty新增的属性,该新属性是不可修改、不可删除以及不可枚举的
속성에 대해 보다 정확한 운영 제어를 원할 경우
Object.defineProperty
를 사용해야 합니다.
속성 설명자는 데이터 설명자와 액세스 설명자의 두 가지 유형으로 나뉩니다.
2.1 데이터 설명자
데이터 설명자는 값이 있는 속성입니다. 쓰기 가능 또는 쓰기 불가능. 데이터 설명자에는 다음과 같은 선택적 키 값이 있습니다.
configurable: 속성의 configurable이 true인 경우에만 속성 설명자가 변경될 수 있으며 해당 개체에서 속성이 삭제될 수도 있습니다. 기본값은 거짓입니다.
enumerable: 속성의 열거 가능이 true인 경우에만 속성이 객체의 열거 속성에 나타날 수 있습니다. 기본값은 거짓입니다.
var obj = { name: 'jam', age: 8 } Object.defineProperty(obj, 'address', { value: '河北', // configurable 该属性不可删除,更不可再次使用defineProperty修改属性描述符 configurable: false, }) delete obj.address // 想使用delete删除该属性 obj.address = '广州' // 想修改obj中的属性address值为广州 console.log(obj.address) // 输出结果:河北obj: 찾을 대상 개체 🎜🎜prop: 대상 개체의 속성 이름(문자열 형식). 🎜🎜반환 값: 지정된 속성이 개체에 존재하는 경우 해당 속성 설명자 개체를 반환하고, 그렇지 않으면 정의되지 않음을 반환합니다. 🎜🎜🎜🎜참고: 이 메서드의 첫 번째 매개 변수가 개체가 아닌 경우 오류(TypeError)가 보고됩니다. 🎜🎜🎜2.1.2 속성 설명자 설정 Object.defineProperty🎜
🎜Object.defineProperty() 메서드는 객체에 대한 새 속성을 직접 정의하거나 객체의 기존 속성을 수정합니다. 이 객체를 반환합니다. 🎜var obj = { name: 'jam', age: 8}Object.defineProperty(obj, 'sex ', { value: '男', // enumerable 配置该属性是否可以枚举 enumerable: true})for (i in obj) { console.log(i)}🎜🎜obj: 속성을 정의할 개체입니다. 🎜🎜prop: 정의하거나 수정할 속성의 이름입니다. 🎜🎜descriptor: 정의하거나 수정할 속성 설명자 🎜🎜반환 값: 함수 🎜🎜var obj = { name: 'jam', age: 8}Object.defineProperty(obj, 'score', { value: 80, // writable: true writable: false})obj.score = 100 console.log(obj.score) // 80🎜🎜에 전달된 개체참고: DefineProperty를 통해 추가된 새 속성은 수정하거나 삭제할 수 없습니다.🎜🎜🎜🎜(1) 객체에서 configurable 삭제 가능 여부🎜🎜<pre class="brush:php;toolbar:false">Object.defineProperties(obj,props)</pre>🎜🎜속성 설명자 구성 가능 값이 false이고 삭제 및 수정이 불가능하므로 삭제 및 수정이 적용되지 않습니다🎜🎜 🎜🎜( 2) enumerable을 열거하고 순회할 수 있는지 여부🎜🎜<pre class="brush:php;toolbar:false">var obj = { name: 'jam',}Object.defineProperties(obj, { 'age': { value: 28, writable: true, configurable: false, enumerable: true }, 'job': { value: '律师', writable: true, configurable: false, enumerable: true }, 'sex': { value: '男', writable: false, configurable: false, enumerable: true }, 'height': { value: '1.8 m', writable: false, configurable: false, enumerable: true }})console.log(obj) // name: 'jam', age: 28, job: '律师', sex: '男', height: '1.8m' }</pre>🎜🎜enumerable: false일 경우 출력 결과는 이름 age🎜 enumerable: true일 경우 출력 결과는 name age sex🎜🎜🎜🎜 (3) 쓰기 가능 여부를 제어하는 기능입니다. 속성에 값을 할당할 수 있습니다(값 쓰기)🎜🎜<pre class="brush:php;toolbar:false">var obj = { name: 'jam', age: 8, _address: '河北' } // 存取描述符的使用场景 // 1.隐藏某一个私有属性被希望直接被外界使用和赋值 // 2.如果我们希望解惑某一个属性它访问和设置值的过程时,也会使用存储属性描述符 Object.defineProperty(obj, 'address', { enumerable: true, configurable: true, get: function () { foo() return this._address }, set: function (value) { bar() this._address = value } }) function foo () { console.log("截获了一次address的值") } function bar () { console.log("设置了一次address的值") }</pre>🎜🎜writeable 값이 false이므로 점수를 100으로 수정하면 수정이 실패하고 최종 출력은 80이 됩니다🎜
是不是感觉每次只能设置一个属性的属性描述符很繁琐,Object.defineProperties可以帮你解决问题。
Object.defineProperties()方法为对象定义一个或多个新属性或修改现有属性,并返回该对象。
Object.defineProperties(obj,props)
示例代码如下:
var obj = { name: 'jam',}Object.defineProperties(obj, { 'age': { value: 28, writable: true, configurable: false, enumerable: true }, 'job': { value: '律师', writable: true, configurable: false, enumerable: true }, 'sex': { value: '男', writable: false, configurable: false, enumerable: true }, 'height': { value: '1.8 m', writable: false, configurable: false, enumerable: true }})console.log(obj) // name: 'jam', age: 28, job: '律师', sex: '男', height: '1.8m' }
存取描述符是由getter-setter函数对描述的属性。存取描述符具有以下可选键值:
configurable 和 enurnerable 的使用与数据描述符中的一致,这里就不过多讲解了。
主要讲一下get 和 set 方法的使用
var obj = { name: 'jam', age: 8, _address: '河北' } // 存取描述符的使用场景 // 1.隐藏某一个私有属性被希望直接被外界使用和赋值 // 2.如果我们希望解惑某一个属性它访问和设置值的过程时,也会使用存储属性描述符 Object.defineProperty(obj, 'address', { enumerable: true, configurable: true, get: function () { foo() return this._address }, set: function (value) { bar() this._address = value } }) function foo () { console.log("截获了一次address的值") } function bar () { console.log("设置了一次address的值") }
上述示例代码控制台打印结果如下:
【相关推荐:javascript视频教程、web前端】
위 내용은 속성 설명자의 JavaScript 객체 지향 상세 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!