Vue之计算属性(computed)

Vue之计算属性(computed)计算属性以上就是计算属性的大致讲解

大家好,欢迎来到IT知识分享网。


前言

计算属性


一、计算属性

  1. 定义:要用的属性不存在,要通过已有的属性来计算。
  2. 原理:底层借助了Object.defineproperty方法提供的getter和setter。(如果不了解getter和setter可以看一下我数据代理那篇文章的讲解)
  3. get函数的执行:
    (1)初次读取时会执行一次。
    (2)当依赖的数据发生变化时会再次调用。

  4. 优势:与methods实现相比,内部有缓存机制(复用),效率更高,调试方便。
  5. 备注:
    (1)计算属性最终会出现在Vue实例上,直接读取使用即可。
    (2)如果计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生改变。

如果不太明白请继续往下看

二、实例

1.缓存优势

计算属性内部的属性,在第一次访问时会读取它的值,然后存入缓存

代码如下(示例):

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <div id="root"> 姓:<input type="text" v-model="name1"><br> 名: <input type="text" v-model="name2"><br> 全称: <input type="text" v-model="fullname"> <input type="text" v-model="fullname"> <input type="text" v-model="fullname"> </div> <script> var vm = new Vue({ 
        el: "#root", data: { 
        name1: '王', name2: '五' }, computed: { 
        fullname: { 
        get() { 
        console.log("有人读取了fullname"); return this.name1 + '-' + this.name2 }, set(value) { 
        arr = value.split("-") this.name1 = arr[0] this.name2 = arr[1] } } } }) </script> </body> </html> 

在这里插入图片描述
在这里插入图片描述
由上面代码和控制台图片分析:代码中有三个input框都绑定了fullname的值,但是在控制台就打印了一次‘有人读取了fullname’(注:get函数在属性被访问时触发),正常逻辑应该调用get三次、读取三次,实际上是因为计算属性内部有缓存,第一次访问后,后面的都直接访问缓存内的数据,节约时间,复用高。但是又有疑问了,有了缓存,但是当fullname发生改变,那是否还是读取的原缓存的值呢?
在这里插入图片描述


在这里插入图片描述
我在输入框内输入了123这三个数,输入过程中下面的控制台每输入一个数字,就有个‘有人读取了fullname’。
其实这个例子就想告诉大家,计算属性内属性的get在第一次读取时,和所依赖的数据发生改变时都会调用。大家可以改变姓、名发现是一样的会被调用

2.简写

简写其实就是当确定计算属性内的属性只读不更改,即只有get函数没有写set函数时简写的方式

代码如下(示例):

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <script type="text/javascript" src="../js/vue.js"></script> </head> <body> <div id="root"> 姓:<input type="text" v-model="name1"><br> 名: <input type="text" v-model="name2"><br> 全称: <input type="text" v-model="fullname"> <input type="text" v-model="fullname"> <input type="text" v-model="fullname"> </div> <script> var vm = new Vue({ 
        el: "#root", data: { 
        name1: '王', name2: '五' }, computed: { 
        fullname() { 
        console.log("有人读取了fullname"); return this.name1 + '-' + this.name2 } } }) </script> </body> </html> 

在这里插入图片描述
需要注意一下,上诉fullname并不是函数,所以在容器内书写的时候不能带括号,fullname在Vue实例身上仍然是一个属性
在这里插入图片描述

3.补充


总结

以上就是计算属性的大致讲解。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/110216.html

(0)
上一篇 2026-02-02 07:45
下一篇 2026-02-02 08:11

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信