vue是如何进行监听数据变化的?

简介: vue是如何进行监听数据变化的?

Vue.js使用数据劫持(Data Observation)的方式来监听数据变化。


在Vue.js中,当创建Vue实例时,会将数据对象进行递归遍历,并使用Object.defineProperty方法对每个属性进行劫持。这样一来,当数据发生变化时,就能够在底层触发相应的get和set方法,从而实现监听数据变化的能力。当数据被修改时,Vue会通知相关的视图更新。


Vue2和Vue3是Vue.js的两个版本。


Vue2:

  • Vue2是较早版本的Vue.js,也是目前较为广泛使用的版本。
  • 使用的是基于原型链和getter/setter的数据劫持方式,通过Object.defineProperty对数据进行劫持。
  • Vue2在性能和体积方面存在一些限制,并且在一些复杂场景下可能表现不佳。


Vue3:

  • Vue3是Vue.js的最新版本,于2020年9月正式发布。
  • 采用了基于Proxy的数据劫持方式,代替了Vue2中的Object.defineProperty。
  • Vue3在性能和开发体验上有所优化,具有更好的运行时性能和更小的包体积。
  • Vue3还引入了一些新特性,如Composition API、Fragment等,提供了更灵活和可组合的开发方式。


Vue3更换数据劫持方式的原因是,Proxy相较于Object.defineProperty具有更强大的能力和更好的性能。Proxy可以代理整个对象,而不仅限于属性的劫持,同时也可以监控数组的变化。

举例:

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="changeMessage">Change Message</button>
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      message: 'Hello Vue!'
    }
  },
  methods: {
    changeMessage() {
      this.message = 'Hello World!'
    }
  }
}
</script>


在上述例子中,当点击按钮时,调用changeMessage方法修改了message的值,Vue会自动检测到数据变化并更新相关视图,将新值展示在页面上。这是因为Vue通过数据劫持监听到了message属性的变化,并进行了相应的响应式更新。



相关文章
|
2天前
|
JavaScript 前端开发
Vue,如何引入样式文件
Vue,如何引入样式文件
|
2天前
|
JavaScript
|
1天前
|
JavaScript 开发工具 git
大事件项目40---Vue代码里如何引入相对路径图片
大事件项目40---Vue代码里如何引入相对路径图片
|
2天前
|
JavaScript
vue滚动到页面底部时加载
vue滚动到页面底部时加载
5 1
|
2天前
|
JavaScript 前端开发
一个好看的vue admin模板
这是一个关于Vue管理模板的引用,提到了[PanJiaChen](https://github.com/PanJiaChen/vue-admin-template)在GitHub上的`vue-admin-template`项目。该项目是一个前端管理模板,链接指向了详细的资源。页面中还包含了一张图片,但markdown格式中无法直接显示。简而言之,这是关于一个基于Vue的后台管理界面模板的参考信息。
|
2天前
|
资源调度 JavaScript API
Vue-treeselect:为Vue应用程序提供强大选择器的指南
Vue-treeselect:为Vue应用程序提供强大选择器的指南
6 0
|
2天前
|
JavaScript
vue知识点
vue知识点
5 0
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1006 0
|
2天前
|
JavaScript 前端开发 API
|
2天前
|
JavaScript 前端开发 网络架构
Vue如何实现页面跳转路由,实现单页面跳转
Vue如何实现页面跳转路由,实现单页面跳转