Vue之计算属性(computed)

news/2024/11/29 10:52:34/

文章目录

  • 前言
  • 一、计算属性
  • 二、实例
    • 1.缓存优势
      • 计算属性内部的属性,在第一次访问时会读取它的值,然后存入缓存
    • 2.简写
      • 简写其实就是当确定计算属性内的属性只读不更改,即只有get函数没有写set函数时简写的方式
    • 3.补充
  • 总结


前言

计算属性


一、计算属性

  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.补充

最后补充一下,computed内的属性最后是在Vue实例身上,并不在Vue实例的_data身上,只有data内的属性才在Vue的_data上。
在这里插入图片描述


总结

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


http://www.ppmy.cn/news/662145.html

相关文章

为什么苹果手机通话的时候不能录音?

讲道理&#xff0c;给手机通话加一个录音功能并不复杂&#xff0c;以苹果公司的实力&#xff0c;这就是小菜一碟。之所以不能录音&#xff0c;不是不能做&#xff0c;而是不愿做。 不能录音是更多是对隐私的重视 为啥这样说&#xff1f;因为苹果手机不仅不能在通话界面录音&am…

android 拨打电话音量,手机音量键都按到最大了,通话声音还是很小?试试打开这个功能...

我们在使用手机打电话的时候&#xff0c;总希望声音能够大一些&#xff0c;特别是对于一些年纪稍大的朋友来讲。可是&#xff0c;每次把音量键调到最大&#xff0c;通话声音依旧不够大&#xff0c;而且有时候还带有杂音。如果手机通话出现了这种情况&#xff0c;应该怎么解决呢…

vue-router.esm.js:2248 Error: Cannot find module ‘@/views/dylife/ 报错解决

具体是展示 一直加载 控制台报找不到模块 webpack版本问题&#xff0c;webpack4 不支持变量方式的动态 import &#xff0c;新版本需要使用 require() 来解决此问题。 return () > import(/views/${view}) 改写成 return (resolve) > require([/views/${view}], reso…

PD快充协议诱骗芯片XSP01 支持 iPhone无线充电9V或12V

一、概述 XSP01是一颗符合PD、QC2.0、QC3.0、AFC、FCP协议的电源受电端协议芯片&#xff0c;可广泛应用于各个领域的各种产品&#xff0c;如无线充电、小家电、老化器、电子烟等。 1.1、芯片特性 支持PD快充协议适配器 支持QC2.0、QC3.0、AFC协议适配器&#xff08;定制版&…

英集芯IP5566带TYPE-C口3A充放快充移动电源5w无线充二合一方案SOC

一、英集芯Ip5566无线充二合一方案SOC简介&#xff1a; 英集芯Ip5566是一款带TYPE-C口3A充放快充移动电源5w无线充二合一方案SOC&#xff0c;集成升压转换器、锂电池充电管理、电池电量指示、无线充电发射控制的多功能电源管理芯片&#xff0c;为无线充的移动电器提供完整的解决…

支持给手机充电(快充)的无线领夹麦克风解决方案

在生活中&#xff0c;需要用到无线领夹麦克风的应该场景&#xff0c;越来越多&#xff0c;比如网红直播&#xff0c;网课教学&#xff0c;采访录音&#xff0c;视频录制&#xff0c;视频会议等等。然而&#xff0c;目前的手机基本都已取消Audio3.5耳机接口&#xff0c;要实现音…

这个充电宝不仅支持无线充,关键还小

现如今我们出门时&#xff0c;手机几乎都是随身携带 支付用手机&#xff0c;移动办公用手机&#xff0c;刷剧玩游戏用手机 手机可以说与我们工作&#xff0c;生活密不可分。 只不过手机频率使用如此之高&#xff0c;也使得用电量大增 当手机没电的时候&#xff0c;感觉一下子与…

7.5W10W无线充电解决方案原理图

7.5W、10W手机无线充电解决方案原理图 支持苹果、三星手机快速无线充电&#xff0c;支持5W无线充电&#xff0c;可以快速通过qi认证和其它各项认证。