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

 更新时间:2022年11月17日 09:33:45   作者:兮动人  
这篇文章主要介绍了vue之计算属性的缓存computed的用法解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue计算属性的缓存computed用法

计算属性的缓存

我们可能会考虑这样的一个问题:methods和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 计算属性会立即返回之前的计算结果,而不必再次执行函数。

就拿第一个例子来说:

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue实现购物车抛物线小球动画效果的方法详解

    vue实现购物车抛物线小球动画效果的方法详解

    这篇文章主要介绍了vue实现购物车抛物线小球动画效果的方法,结合实例形式较为详细的分析了vue.js实现抛物线动画效果购物车功能相关原理与操作注意事项,需要的朋友可以参考下
    2019-02-02
  • vue3中的组件间的传值(props)

    vue3中的组件间的传值(props)

    这篇文章主要介绍了vue3中的组件间的传值(props)问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • vue-cli创建vue项目的详细步骤记录

    vue-cli创建vue项目的详细步骤记录

    vue.cli是vue中的项目构造工具,是一个npm包,需要安装node.js和 git才能用,下面这篇文章主要给大家介绍了关于利用vue-cli创建vue项目的详细步骤,需要的朋友可以参考下
    2022-06-06
  • 一文搞懂Vue3中的异步组件defineAsyncComponentAPI的用法

    一文搞懂Vue3中的异步组件defineAsyncComponentAPI的用法

    这篇文章主要介绍了一文搞懂Vue3中的异步组件,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-07-07
  • vue-router中的钩子函数和执行顺序说明

    vue-router中的钩子函数和执行顺序说明

    这篇文章主要介绍了vue-router中的钩子函数和执行顺序说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • vue.js项目使用原生js实现移动端的轮播图

    vue.js项目使用原生js实现移动端的轮播图

    这篇文章主要为大家介绍了vue.js项目中使用原生js实现移动端的轮播图,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • vue实现pdf文件发送到邮箱功能的示例代码

    vue实现pdf文件发送到邮箱功能的示例代码

    这篇文章主要介绍了vue实现pdf文件发送到邮箱功能,实现代码包括对邮箱格式内容是否为空的验证方法,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • 详解如何将 Vue-cli 改造成支持多页面的 history 模式

    详解如何将 Vue-cli 改造成支持多页面的 history 模式

    本篇文章主要介绍了详解如何将 Vue-cli 改造成支持多页面的 history 模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Elemenu中el-table中使用el-popover选中关闭无效解决办法(最新推荐)

    Elemenu中el-table中使用el-popover选中关闭无效解决办法(最新推荐)

    这篇文章主要介绍了Elemenu中el-table中使用el-popover选中关闭无效解决办法(最新推荐),因为在el-table-column里,因为是多行,使用trigger="manual" 时,用v-model="visible"来控制时,控件找不到这个值,才换成trigger="click",需要的朋友可以参考下
    2024-03-03
  • vue中element-ui表格缩略图悬浮放大功能的实例代码

    vue中element-ui表格缩略图悬浮放大功能的实例代码

    element-ui界面非常简洁和美观,提供的组件可以满足绝大多数的应用场景,当表格中显示了图片的缩略图时,想要鼠标浮动在缩略图上时放大图片的效果,该如何实现呢?下面小编通过实例代码给大家介绍vue中element-ui表格缩略图悬浮放大功能,一起看看吧
    2018-06-06

最新评论