news 2026/5/1 6:15:41

Vue2响应式数据的核心方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue2响应式数据的核心方法

Object.defineProperty() 是 JavaScript 中用于精确控制对象属性行为的核心方法,它允许你为对象定义新属性,或修改已有属性的特性(如是否可枚举、可修改、可删除等),是实现数据劫持(如 Vue 2 响应式)的基础。

语法

Object.defineProperty(obj, prop, descriptor)

参数

说明

obj

要定义 / 修改属性的目标对象

prop

要定义 / 修改的属性名(字符串 / Symbol)

descriptor

属性描述符(对象),分两种类型:数据描述符、存取描述符

描述符只能是以下两种类型之一,不能混合使用(value/writableget/set互斥):

1. 数据描述符(控制属性值相关)

包含以下可选键:

value:属性的值(任意类型,默认 undefined)

writable:是否可修改属性值(布尔值,默认 false)

enumerable:是否可枚举(for...in/Object.keys 能否遍历到,默认 false)

configurable:是否可配置(能否删除属性 / 修改描述符,默认 false)

例如:

const obj = {}; // 定义数据描述符属性 Object.defineProperty(obj, 'name', { value: '张三', writable: false, // 不可修改 enumerable: false, // 不可枚举 configurable: true // 可配置(后续可修改描述符/删除) }); //configurable: false 的限制: //1.无法修改 enumerable、configurable 本身 //2.无法把 writable: false 改为 true(反之可以) //3.无法删除该属性 //4.无法把数据描述符改为存取描述符(反之也不行) console.log(obj.name); // 张三 obj.name = '李四'; // 严格模式下报错,非严格模式无效果 console.log(obj.name); // 张三(未被修改) console.log(Object.keys(obj)); // [](不可枚举) delete obj.name; // 可删除(configurable: true) console.log(obj.name); // undefined

2. 存取描述符(控制属性的读写逻辑)

包含以下可选键:

get:取值函数(访问属性时触发,默认 undefined)

set:存值函数(修改属性时触发,接收新值作为参数,默认 undefined)

enumerable:是否可枚举(默认 false)

configurable:是否可配置(默认 false)

例如:

const obj = { age: 18 }; // 定义存取描述符属性 Object.defineProperty(obj, 'age', { get() { console.log('读取age属性'); return this.age; }, set(newVal) { console.log('修改age属性为:', newVal); if (newVal < 0) { this.age = 0; } else { this.age = newVal; } }, enumerable: true, configurable: true }); console.log(obj.age); // 读取age属性 → 18 obj.age = 20; // 修改age属性为:20 console.log(obj.age); // 读取age属性 → 20 obj.age = -5; // 修改age属性为:-5 console.log(obj.age); // 读取age属性 → 0

Object.defineProperty 只能定义单个属性,如需批量定义,可使用 Object.defineProperties;

对于数组,Object.defineProperty 无法拦截通过索引修改数组的行为(如 arr[0] = 1),Vue 2 中通过重写数组方法(push/pop 等)解决;

ES6 后新增的 Proxy 替代 Object.defineProperty 实现更全面的对象拦截(支持数组、动态属性等),但兼容性稍差。


总结就是,Object.defineProperty()是Vue2用来将data中的属性定义存取描述符(getter/setter)实现数据拦截的方法

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 5:18:58

跨平台文档预览解决方案:告别格式兼容烦恼

跨平台文档预览解决方案&#xff1a;告别格式兼容烦恼 【免费下载链接】kkFileView Universal File Online Preview Project based on Spring-Boot 项目地址: https://gitcode.com/GitHub_Trending/kk/kkFileView 在数字化办公环境中&#xff0c;我们经常面临这样的困扰…

作者头像 李华
网站建设 2026/4/28 8:27:15

React Native Snap Carousel 实战指南:从零开始构建流畅轮播体验

React Native Snap Carousel 实战指南&#xff1a;从零开始构建流畅轮播体验 【免费下载链接】react-native-snap-carousel 项目地址: https://gitcode.com/gh_mirrors/rea/react-native-snap-carousel 在前端开发领域&#xff0c;React Native Snap Carousel 是一个专…

作者头像 李华
网站建设 2026/4/30 11:43:29

专业开发小程序的公司开发一个小程序怎么什么样的?

小程序分类1. 按平台分类微信小程序&#xff1a;基于微信生态&#xff0c;用户基数大&#xff0c;开发文档完善。支付宝小程序&#xff1a;聚焦商业和生活服务场景&#xff0c;与阿里生态深度结合。百度智能小程序&#xff1a;依托搜索流量&#xff0c;支持开源生态。字节跳动小…

作者头像 李华
网站建设 2026/4/26 7:30:54

Qdrant向量数据库架构深度解析:从源码到高性能实战

Qdrant向量数据库架构深度解析&#xff1a;从源码到高性能实战 【免费下载链接】qdrant Qdrant - 针对下一代人工智能的高性能、大规模向量数据库。同时提供云端版本 项目地址: https://gitcode.com/GitHub_Trending/qd/qdrant 想要真正掌握Qdrant向量数据库的高性能奥秘…

作者头像 李华
网站建设 2026/4/19 7:13:59

5分钟搞定HTML转PDF:DOMPDF让PHP文档生成变得如此简单

5分钟搞定HTML转PDF&#xff1a;DOMPDF让PHP文档生成变得如此简单 【免费下载链接】dompdf HTML to PDF converter for PHP 项目地址: https://gitcode.com/gh_mirrors/do/dompdf 还在为PDF文档生成而烦恼吗&#xff1f;DOMPDF这个强大的PHP库能帮你轻松解决这个问题&am…

作者头像 李华