Vue 的数据代理机制

2025/4/22

一、什么是数据代理机制

通过访问代理对象的属性 ,来间接访问目标对象的属性,数据代理机制的实现需要依赖Object.defineProperty()方法。

如下所示:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
    <title>初识VM</title>
</head>
<body>
    <div id="app">
        <h1>{{msg}}</h1>
    </div>
    <script>
        // 目标对象
        let target = {
            name : "apple"
        }

        // 代理对象
        let proxy = {}

        // 使用object.defineProperty 为代理对象新增属性
        Object.defineProperty(proxy,'name',{
            get : function() {
                return target.name
            },
            set : function(val){
                target.name = val
            }
        })
    </script>
    
</body>
</html>

建立的目标对象,代理对象,依赖Object.defineProperty()方法实现了访问访问代理对象的属性 ,来间接访问目标对象的属性。

二、进一步解释vm.msg

html 复制代码
<script>
    const vm = new Vue({
        el : "#app",
        data :{
            msg : "hello vue!"
        }
    })
</script>
                  ||
                  || 
                  \/  
<script>
    let obj = {
            msg : "hello vue!"
    }
    const vm = new Vue({
        el : "#app",
        data : obj 
    })
</script>

为什么如上代码,我们可以通过vm.msg放问到该属性,为什么可以通过vm.msg访问到obj.的属性呢,其实vm就类似于是一个目标对象,vue框架会自动的把 data 选项中的属性转换为响应式属性,同时将这些属性代理到 Vue 实例上,通过Object.defineProperty()方法实现。

三、数据代理时属性名的要求

Vue实例不会给以 _ 和 $ 开始的属性名微数据代理。为什么?

如果允许给_或开始的属性名做数据代理的话。vm这个Vue实例上可能会出现_xxx或xxx命名,这个属性名可能会和Vue框架自身的属性名冲突。所以在Vue当中,给data对象的属性名命名的时候,不能以_或$开始。

相关推荐
一袋米扛几楼9810 分钟前
【网络安全】SIEM -Security Information and Event Management 工具是什么?
前端·安全·web安全
小陈工21 分钟前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
Cobyte30 分钟前
3.响应式系统基础:从发布订阅模式的角度理解 Vue2 的数据响应式原理
前端·javascript·vue.js
竹林81833 分钟前
从零到一:在React前端中集成The Graph查询Uniswap V3池数据实战
前端·javascript
Mintopia41 分钟前
别再迷信"优化":大多数性能问题根本不在代码里
前端
倾颜41 分钟前
接入 MCP,不一定要先平台化:一次 AI Runtime 的实战取舍
前端·后端·mcp
军军君0143 分钟前
Three.js基础功能学习十八:智能黑板实现实例五
前端·javascript·vue.js·3d·typescript·前端框架·threejs
恋猫de小郭44 分钟前
Android 上为什么主题字体对 Flutter 不生效,对 Compose 生效?Flutter 中文字体问题修复
android·前端·flutter
Moment1 小时前
AI全栈入门指南:一文搞清楚NestJs 中的 Controller 和路由
前端·javascript·后端
禅思院1 小时前
前端架构演进:基于AST的常量模块自动化迁移实践
前端·vue.js·前端框架