vue之计算属性的缓存computed的用法解读
vue计算属性的缓存computed用法
计算属性的缓存
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <!--1.直接拼接:语法过于繁琐--> <h2>{{firstName}} {{lastName}}</h2> <!--2.通过定义methods--> <h2>{{getFullName()}}</h2> <!--3.通过computed--> <h2>{{fullName}}</h2> </div> <script src="../js/vue.js"></script> <script> const app = new Vue({ el: '#app', data: { firstName: 'Kobe', lastName: 'Bryant' }, methods: { getFullName: function () { return this.firstName+' '+this.lastName } }, computed: { fullName: function () { return this.firstName+' '+this.lastName } } }) </script> </body> </html>
在多次循环使用时,methods时会多次调用,而computed只调用一次
computed计算属性设置与缓存问题
简单的一些小计算可以直接用模板内的表达式计算,比较复杂一点的就建议使用“计算属性来运算了”,也方便后期的维护;
vue所有的计算属性都以函数的形式写在Vue实例内的computed里面,返回计算后的数据。
- 计算属性可以同时按多个Vue实例来计算,只要其中任何一个数据发生变化,
- 计算属性就会重新计算一遍,返回新的数据,相对的刷新视图中的数据
比如:
<div id="v1"> <!--这里显示的是computed中的函数--> 共计:{{ total }} </div> <script src="vue.min.js"></script> <script> var app=new Vue({ el:"#v1", data:{ val:[ { price: 199,num:30}, { price: 299,num:20}, { price: 399,num:10} ] }, computed:{ total:function () { var vel=this.val; var sum=0,len=vel.length; for(var i=0;i<len;i++){ sum+=vel[i].price * vel[i].num } return sum; } } }) </script>
每个计算属性都有一个getter函数 和 setter函数,上面的示例只是用了computed的唯一默认属性,就是getter , setter一般用来手动修改数据
<div id="v1"> {{ value }} </div> <script src="vue.min.js"></script> <script> var app=new Vue({ el:"#v1", data:{ first:"Sherlock", second:"love", third:"John" }, computed:{ value: { get:function () { //getter读取数据 return this.first + " ~ " + this.second + " ~ " + this.third }, set:function (val) { //setter 需要时触发 var result=val.split(" ~ "); this.first=result[0]; this.third=result[2]; } } } }); app.value="John ~ love ~ Sherlock"; //在这里触发setter </script>
另外,计算属性不仅可以通过当前的当前的实例数据计算,也可以做到 “跨实例” 取值,用法如下:
<script> var v1=new Vue({ el:"#v1", data:{ num:1 } }); var v2=new Vue({ el:"#v2", data:{ num:2 }, computed:{ total:function () { var n1="我是上一个实例的数据 :"+v1.num, n2="我是本实例的数据:"+this.num; return n1 +" ............. " +n2; } } }) </script>
页面显示:
对于computed计算属性来说还有一个很重要的作用就是:缓存
一般情况下,computed(计算属性) 和 methods(方法)执行出来的效果是一样的,
但是computed的好处是:
只有在与它相关或者需要的数据发生改变时才会重新求值。
这就意味着只要 我们在计算时设置的数据还没有发生改变,即使多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。
就拿第一个例子来说:
相对的,每当触发重新渲染时,调用方法将总会再次执行函数。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
一文搞懂Vue3中的异步组件defineAsyncComponentAPI的用法
这篇文章主要介绍了一文搞懂Vue3中的异步组件,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-07-07详解如何将 Vue-cli 改造成支持多页面的 history 模式
本篇文章主要介绍了详解如何将 Vue-cli 改造成支持多页面的 history 模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11Elemenu中el-table中使用el-popover选中关闭无效解决办法(最新推荐)
这篇文章主要介绍了Elemenu中el-table中使用el-popover选中关闭无效解决办法(最新推荐),因为在el-table-column里,因为是多行,使用trigger="manual" 时,用v-model="visible"来控制时,控件找不到这个值,才换成trigger="click",需要的朋友可以参考下2024-03-03vue中element-ui表格缩略图悬浮放大功能的实例代码
element-ui界面非常简洁和美观,提供的组件可以满足绝大多数的应用场景,当表格中显示了图片的缩略图时,想要鼠标浮动在缩略图上时放大图片的效果,该如何实现呢?下面小编通过实例代码给大家介绍vue中element-ui表格缩略图悬浮放大功能,一起看看吧2018-06-06
最新评论