vue之计算属性的缓存computed的用法解读

作者:兮动人 时间:2024-05-11 09:14:05 

vue计算属性的缓存computed用法

计算属性的缓存

vue之计算属性的缓存computed的用法解读

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>

vue之计算属性的缓存computed的用法解读

在多次循环使用时,methods时会多次调用,而computed只调用一次

computed计算属性设置与缓存问题

简单的一些小计算可以直接用模板内的表达式计算,比较复杂一点的就建议使用&ldquo;计算属性来运算了&rdquo;,也方便后期的维护;

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>

另外,计算属性不仅可以通过当前的当前的实例数据计算,也可以做到 &ldquo;跨实例&rdquo; 取值,用法如下:

<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>

页面显示:

vue之计算属性的缓存computed的用法解读

对于computed计算属性来说还有一个很重要的作用就是:缓存

一般情况下,computed(计算属性) 和 methods(方法)执行出来的效果是一样的,

但是computed的好处是:

只有在与它相关或者需要的数据发生改变时才会重新求值。

这就意味着只要 我们在计算时设置的数据还没有发生改变,即使多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

就拿第一个例子来说:

vue之计算属性的缓存computed的用法解读

相对的,每当触发重新渲染时,调用方法将总会再次执行函数。

来源:https://xdr630.blog.csdn.net/article/details/108925842

标签:vue,计算属性,缓存,computed
0
投稿

猜你喜欢

  • python得到电脑的开机时间方法

    2021-01-05 08:00:05
  • Java面试题冲刺第十二天--数据库(2)

    2024-01-21 18:34:27
  • css网页下拉菜单制作方法(4):定位问题

    2007-02-03 11:39:00
  • 求任意自然数内的素数

    2009-10-15 12:21:00
  • 使用python 和 lint 删除项目无用资源的方法

    2023-10-22 16:56:08
  • 浅析python3字符串格式化format()函数的简单用法

    2021-03-26 15:05:49
  • 使用python实现希尔、计数、基数基础排序的代码

    2023-07-12 09:02:24
  • 谈谈如何手动释放Python的内存

    2023-09-22 13:03:57
  • Flowable数据库表分类及数据字典解析

    2024-01-14 16:55:10
  • asp如何远程注册DLL

    2010-06-16 09:58:00
  • Javascript模拟加速运动与减速运动代码分享

    2024-06-07 15:27:46
  • python3 tkinter实现点击一个按钮跳出另一个窗口的方法

    2023-10-27 01:19:11
  • Python数据分析Pandas Dataframe排序操作

    2022-06-28 07:44:11
  • Python 等分切分数据及规则命名的实例代码

    2023-03-26 05:01:17
  • python+OpenCV实现图像拼接

    2023-01-28 08:09:26
  • Python异常处理知识点总结

    2023-01-04 16:03:36
  • asp+jsp+JavaScript动态实现添加数据行

    2023-07-03 05:37:15
  • 浅谈PHP的反射机制

    2023-06-13 17:05:35
  • python使用正则表达式匹配反斜杠\\遇到的问题

    2021-12-19 19:45:05
  • JS中如何优雅的使用async await详解

    2024-05-02 16:19:23
  • asp之家 网络编程 m.aspxhome.com