news 2026/4/18 5:56:11

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/17 9:02:49

三步搞定.NET Framework 3.5自动化部署:Windows系统管理员的救星

三步搞定.NET Framework 3.5自动化部署&#xff1a;Windows系统管理员的救星 【免费下载链接】.NETFramework3.5一键安装工具 本仓库提供了一个方便快捷的资源文件&#xff0c;用于一键安装.NET Framework 3.5。该工具适用于需要在Windows系统上快速部署.NET Framework 3.5的用…

作者头像 李华
网站建设 2026/4/18 7:03:57

腾讯开源视频生成新标杆:HunyuanVideo的技术突破与应用前景

腾讯开源视频生成新标杆&#xff1a;HunyuanVideo的技术突破与应用前景 【免费下载链接】HunyuanVideo-PromptRewrite 项目地址: https://ai.gitcode.com/hf_mirrors/tencent/HunyuanVideo-PromptRewrite 在视频生成技术快速发展的今天&#xff0c;腾讯最新开源的Hunyu…

作者头像 李华
网站建设 2026/4/17 12:29:59

19、Ubuntu服务器常见配置指南(上)

Ubuntu服务器常见配置指南(上) 在当今的服务器管理中,Ubuntu系统因其稳定性和易用性受到广泛青睐。本文将为你详细介绍Ubuntu服务器中邮件服务器、OpenSSH服务器以及DHCP服务器的常见配置方法。 1. 邮件服务器配置 1.1 二级邮件服务器设置 若要为 example.org 和 exa…

作者头像 李华
网站建设 2026/4/18 2:56:55

17、网络操作与文件搜索全解析

网络操作与文件搜索全解析 在网络环境中,我们常常需要查看网络路由表、传输文件、安全地与远程主机通信以及搜索文件。下面将详细介绍这些操作及其相关工具。 查看网络路由表 使用 netstat 命令的 -r 选项可以显示内核的网络路由表,它展示了网络如何配置以在不同网络之…

作者头像 李华
网站建设 2026/4/18 5:24:20

我如何使用 Claude Code 的每个功能

我几乎每天都在使用 Claude Code。在个人项目中&#xff0c;我每周会在虚拟机里运行它多次&#xff0c;经常配合 --dangerously-skip-permissions&#xff0c;以“随心编码&#xff08;vibe code&#xff09;”的方式快速把脑中的点子落地。工作中&#xff0c;我们团队的一部分…

作者头像 李华
网站建设 2026/4/18 5:32:34

Oracle LogMiner实战指南:误删误改数据的救命稻草

惊魂时刻&#xff1a;数据误操作的现实困境在日常数据库运维中&#xff0c;数据误操作几乎无法完全避免&#xff1a;误执行DELETE不带WHERE条件&#xff0c;整表数据瞬间消失UPDATE忘记限定范围&#xff0c;全表数据被错误更新DROP表时选错对象&#xff0c;重要业务表意外被删批…

作者头像 李华