当前位置: 首页 > wzjs >正文

无限动力网站百度竞价官网

无限动力网站,百度竞价官网,银川做淘宝网站的,企业网站改版方案在 JavaScript 中,Object.defineProperty() 是一个强大的内置方法,用于精确控制对象属性的配置。它允许你直接修改对象属性的底层特性(如可读写性、可枚举性、可配置性),甚至可以自定义属性的 getter 和 setter 方法。…

在 JavaScript 中,Object.defineProperty() 是一个强大的内置方法,用于精确控制对象属性的配置。它允许你直接修改对象属性的底层特性(如可读写性、可枚举性、可配置性),甚至可以自定义属性的 getter 和 setter 方法。

核心作用

  1. 精确控制属性配置
    通过设置属性描述符(descriptor),可以精确控制属性的行为。
  2. 实现数据劫持
    通过 getter/setter 拦截属性的读取和赋值操作,常用于响应式系统(如 Vue.js 的数据绑定)。
  3. 阻止属性被意外修改
    通过设置 writable: falseconfigurable: false 保护属性不被修改或删除。

基本语法

Object.defineProperty(obj, prop, descriptor);
  • obj:需要定义属性的对象。
  • prop:需要定义或修改的属性名称(字符串或 Symbol)。
  • descriptor:属性描述符对象,包含以下可选键:
    • value:属性的值(默认 undefined)。
    • writable:属性值是否可修改(默认 false)。
    • enumerable:属性是否可被枚举(如 for...in 循环,默认 false)。
    • configurable:属性是否可被删除或重新配置(默认 false)。
    • get:获取属性值的函数(与 value 互斥)。
    • set:设置属性值的函数(与 value 互斥)。

用法示例

1. 基本属性定义
const person = {};Object.defineProperty(person, 'name', {value: 'John',writable: true,     // 允许修改值enumerable: true,   // 可被枚举configurable: true  // 可被重新配置或删除
});console.log(person.name); // "John"
person.name = 'Jane';     // 修改有效(writable: true)
console.log(person.name); // "Jane"
2. 只读属性(writable: false
const person = {};Object.defineProperty(person, 'age', {value: 30,writable: false,    // 只读enumerable: true
});console.log(person.age); // 30
person.age = 31;         // 赋值无效(严格模式下会报错)
console.log(person.age); // 30
3. 不可枚举属性(enumerable: false
const person = { name: 'John' };Object.defineProperty(person, 'age', {value: 30,enumerable: false   // 不可枚举
});console.log(person.age); // 30
for (const key in person) {console.log(key); // 仅输出 "name"(age 不可枚举)
}
4. 不可配置属性(configurable: false
const person = {};Object.defineProperty(person, 'name', {value: 'John',configurable: false  // 不可重新配置或删除
});delete person.name;    // 删除无效
console.log(person.name); // "John"// 尝试重新配置会报错(严格模式下)
Object.defineProperty(person, 'name', {value: 'Jane'
}); // TypeError: Cannot redefine property: name
5. 数据劫持(getter/setter)
const person = {_age: 30 // 约定使用下划线表示私有属性
};Object.defineProperty(person, 'age', {get() {console.log('读取 age');return this._age;},set(newValue) {console.log('设置 age 为', newValue);if (newValue < 0) throw new Error('年龄不能为负数');this._age = newValue;}
});console.log(person.age); // 读取 age → 30
person.age = 31;         // 设置 age 为 31
person.age = -5;         // Error: 年龄不能为负数

应用场景

  1. 实现响应式系统
    Vue.js 2.x 利用 Object.defineProperty() 实现数据劫持,当属性值变化时自动更新 DOM:

    function defineReactive(obj, key, value) {Object.defineProperty(obj, key, {get() {// 依赖收集return value;},set(newValue) {if (value !== newValue) {value = newValue;// 触发更新updateDOM();}}});
    }
    
  2. 实现私有属性
    通过 getter/setter 控制属性访问权限:

    const person = {};
    let _age = 30; // 闭包中的私有变量Object.defineProperty(person, 'age', {get() { return _age; },set(value) { _age = value; }
    });
    
  3. 阻止对象被篡改
    通过设置 configurable: falsewritable: false 保护关键属性:

    const config = { API_KEY: 'secret' };Object.defineProperty(config, 'API_KEY', {writable: false,configurable: false
    });// 无法修改或删除 API_KEY
    

注意事项

  1. 兼容性Object.defineProperty() 是 ES5 引入的方法,不支持 IE8 及以下版本。
  2. 性能影响:频繁触发 getter/setter 会有一定性能开销,避免在高性能场景(如大型循环)中过度使用。
  3. 深度监听Object.defineProperty() 只能监听对象的直接属性,若要监听嵌套对象,需要递归处理。
  4. 数组监听限制:直接监听数组变化存在局限性(Vue.js 3 改用 Proxy 解决此问题)。

Proxy 的对比

特性Object.defineProperty()Proxy
监听范围只能监听对象的已有属性(需逐个定义)可以监听整个对象(包括新增属性)
数组支持对数组的监听有限(需特殊处理)全面支持数组操作
元编程能力仅能控制单个属性可以拦截多种操作(如 indelete
兼容性ES5(支持 IE9+)ES6(不支持 IE)

Object.defineProperty() 是 JavaScript 中强大的元编程工具,适合需要精确控制对象属性行为的场景,尤其在实现响应式系统、数据验证和属性保护等方面有广泛应用。

http://www.dtcms.com/wzjs/274448.html

相关文章:

  • 卫计局本年度网站建设工作总结今日头条搜索优化
  • 做的网站放在阿里云百度上怎么做推广
  • 网站开发团队哪些人西安百度爱采购推广
  • 搜狗推广做网站要钱吗安徽搜索引擎优化seo
  • 微软公司做网站的软件如何让别人在百度上搜到自己公司
  • 湘潭做网站价格咨询磐石网络手机推广app
  • 网站子目录建立seo是指什么
  • 怎么给网站做404武汉网站seo
  • 什么是网站销售北京推广优化经理
  • 建设银行官网站下载南通网络推广
  • 长沙优化科技有限公司正规吗酒店seo是什么意思
  • 沈阳网站前端优化营商环境工作开展情况汇报
  • 电脑做系统ppt下载网站好网络服务器地址怎么查
  • 嘉兴网嘉兴网站建设网络策划是做什么的
  • php如何做局域网的网站建设百度搜索高级搜索
  • 华哥在用wordpress10大插件西安百度seo排名
  • 建立手机个人网站一个具体网站的seo优化
  • 成都网站建设 四川冠辰结构优化是什么意思
  • 青岛建设集团 招聘信息网站电脑优化软件推荐
  • 惠东网站设计上海百度公司地址在哪里
  • 2在线做网站建网站流程
  • 教育机构做网站素材河南省最新通知
  • 金山区网站制作东莞做网站的公司有哪些
  • 免费做网站建设哪些网站可以发广告
  • 个人静态网站首页怎么做新闻稿发布平台
  • 网站建设目标初步目标网络优化是干什么的
  • 怎么做代理人金沙网站百度上首页
  • wordpress 停用多站点拓客最有效方案
  • 快站优惠券去哪里找注册域名要钱吗
  • 做网站日志步骤宁德市中医院