vue计算属性与watch监听
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue计算属性与watch监听相关的知识,希望对你有一定的参考价值。
参考技术A 总结:1. 计算属性computed在使用时,一定要注意,函数里面的变量都会被监听,只要里面的某一个值变动,便会将整个函数执行一遍。 而watch只是监听某一个值,若是监听的值里面也有很多变量,也会全部监听
2. 计算后的属性可不在 data 中定义,如果定义会报错,因为对应的computed作为计算属性定义并返回对应的结果给这个变量,变量不可被重复定义和赋值。 而watch监听data中定义的变量变化
computed特性
1.是计算值,
2.应用:就是简化tempalte里面计算和处理props或$emit的传值
3.具有缓存性,页面重新渲染值不变化,计算属性会立即返回之前的计算结果,而不必再次执行函数
watch特性
1.是观察的动作,
2.应用:监听props,$emit或本组件的值执行异步操作
3.无缓存性,页面重新渲染时值不变化也会执行
接下来介绍下 各自的方法:
链接:https://www.jianshu.com/p/d86ae49a5403
Vue--computed计算属性监听数据变化----与watch,methods对比
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <script src="./lib/vue-2.4.0.js"></script> </head> <body> <div id="app"> <input type="text" v-model="firstname"> + <input type="text" v-model="middlename"> + <input type="text" v-model="lastname"> = <input type="text" v-model="fullname"> <p> fullname </p> <p> fullname </p> <p> fullname </p> </div> <script> // 创建 Vue 实例,得到 ViewModel var vm = new Vue( el: ‘#app‘, data: firstname: ‘‘, lastname: ‘‘, middlename: ‘‘ , methods: , computed: // 在 computed 中,可以定义一些 属性,这些属性,叫做 【计算属性】, 计算属性的,本质,就是 一个方法,只不过,我们在使用 这些计算属性的时候,是把 它们的 名称,直接当作 属性来使用的;并不会把 计算属性,当作方法去调用; // 注意1: 计算属性,在引用的时候,一定不要加 () 去调用,直接把它 当作 普通 属性去使用就好了; // 注意2: 只要 计算属性,这个 function 内部,所用到的 任何 data 中的数据发送了变化,就会 立即重新计算 这个 计算属性的值 // 注意3: 计算属性的求值结果,会被缓存起来,方便下次直接使用; 如果 计算属性方法中,所以来的任何数据,都没有发生过变化,则,不会重新对 计算属性求值; ‘fullname‘: function () console.log(‘ok‘) return this.firstname + ‘-‘ + this.middlename + ‘-‘ + this.lastname ); </script> </body> </html>
以上是关于vue计算属性与watch监听的主要内容,如果未能解决你的问题,请参考以下文章
[每天进步一点点~] vue uni-app 计算属性computed和监听watch