news 2026/5/26 5:22:18

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/5/26 6:53:13

双模切换+6bit量化:Qwen3-14B-MLX-6bit重新定义本地AI部署标准

双模切换6bit量化&#xff1a;Qwen3-14B-MLX-6bit重新定义本地AI部署标准 【免费下载链接】Qwen3-14B-MLX-6bit 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-14B-MLX-6bit 导语 阿里通义千问团队推出的Qwen3-14B-MLX-6bit模型&#xff0c;通过创新的单模…

作者头像 李华
网站建设 2026/5/26 6:52:06

Android TV内存优化实战指南:告别卡顿,提升性能体验

Android TV内存优化实战指南&#xff1a;告别卡顿&#xff0c;提升性能体验 【免费下载链接】my-tv 项目地址: https://gitcode.com/GitHub_Trending/my/my-tv 你是否注意到Android TV应用在使用过程中逐渐变慢&#xff0c;频道切换延迟&#xff0c;甚至遥控器操作失去…

作者头像 李华
网站建设 2026/5/26 6:46:15

别再被VO、BO、PO、DTO、DO绕晕!架构分层对象全解析

引言&#xff1a;为什么我们需要这么多"O"&#xff1f; 在现代Java企业级应用开发中&#xff0c;你是否曾被各种以"O"结尾的对象缩写搞得晕头转向&#xff1f;PO、VO、BO、DTO、DO… 这些看似相似却又各司其职的对象&#xff0c;实际上是企业架构分层思想的…

作者头像 李华
网站建设 2026/5/26 6:47:30

中文大语言模型实战指南:从零构建到行业落地

中文大语言模型实战指南&#xff1a;从零构建到行业落地 【免费下载链接】Awesome-Chinese-LLM 整理开源的中文大语言模型&#xff0c;以规模较小、可私有化部署、训练成本较低的模型为主&#xff0c;包括底座模型&#xff0c;垂直领域微调及应用&#xff0c;数据集与教程等。 …

作者头像 李华
网站建设 2026/5/25 15:16:25

迎接下一代 React 框架:Next.js 16 核心能力解读

Next.js 16 现已正式上线&#xff0c;带来了缓存组件&#xff08;Cache Components&#xff09;、Turbopack 稳定版、精细化缓存等重磅特性。框架此次并未追求大规模重构&#xff0c;而是聚焦基础能力优化------更快的构建速度、可预测的缓存机制、更智能的路由逻辑&#xff0c…

作者头像 李华