【Vue配置项】 computed计算属性 | watch侦听属性

news2025/1/10 17:02:09

目录

前言

computed计算属性

什么是计算属性?

Vue的原有属性是什么?

得到的全新的属性是什么?

计算属性怎么用?

计算属性的作用是什么?

为什么说代码执行率高了?

computed计算属性中的this指向

computed计算属性简写

watch侦听属性

语法格式

watch侦听属性中的this指向

watch深度监视

watch的简写

watch和computed如何选择

异步情况下

computed

watch

watch中异步中箭头函数和普通函数this指向


前言

继上篇文章介绍了Vue配置项中的methods,本文继续介绍Vue配置项中的computed计算属性和watch侦听属性以及在使用如何选择

computed计算属性

什么是计算属性?

使用Vue的原有属性,经过一系列的计算,最终得到了一个全新的属性,叫做计算属性。

Vue的原有属性是什么?

data对象当中的属性可以叫做Vue的原有属性。

得到的全新的属性是什么?

表示生成了一个新的属性,和data中的属性无关了,新的属性也有自己的属性名和属性值。

计算属性怎么用?

语法格式:需要一个新的配置项 computed

computed:{

        计算属性1:{

                get(){

                        当读取计算属性1时,getter方法被自动调用

                },

                set(){

                        当修改计算属性1时,setter方法被自动调用

                }

        },

        计算属性2:{}

}

计算属性的作用是什么?

  1. 代码得到了复用
  2. 代码变得更加容易维护
  3. 代码的执行效率高了

为什么说代码执行率高了?

其实在methods中也可以调用函数方法来完成computed计算属性能完成的事,那为什么会引入computed计算属性呢?

举例

<div class="app">
        <h1>{{msg}}</h1>
        <input type="text" v-model="info">
       {{hh()}}
       {{hh()}}
       {{hh()}}
       {{hh()}}
       {{hh()}}
       {{xx}}
       {{xx}}
       {{xx}}
       {{xx}}
       {{xx}}
        
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{ 
                msg:'computed计算属性',
                info:''
            },
            methods:{
                hh(){
                    console.log('methods方法执行了');
                    return 'hh'
                }
            },
            computed:{
                xx:{
                    get(){
                        console.log('计算属性执行了');
                        return 'xx'
                    }
                }
            }
        })
    </script>

执行此代码,methods中的函数方法以及computed中的计算属性各调用5次

由结果看出,methods中的方法重复执行了5次,而computed计算属性只执行了一次。

这是因为computed计算属性遵循一个缓存机制,将重复存入浏览器中,使用时直接拿出来即可,这样代码的执行效率就变高了

computed计算属性中的this指向

methods中的this是指向vue实例的,那computed计算属性中的this是指向什么呢?

<div class="app">
        <h1>{{msg}}</h1>
        <input type="text" v-model="info">
        {{reverse}}
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{ 
                msg:'computed计算属性',
                info:''
            },
            computed:{
                reverse:{
                    get(){
                       console.log(this);
                    }
                }
            }
        })
    </script>

可知,computed计算属性中的this是指向Vue实例对象的

computed计算属性简写

当不使用set()方法时,仅使用get()方法时可以使用简写

例:反转字符串

 <div class="app">
        <h1>{{msg}}</h1>
        <input type="text" v-model="info">
       字符串反转后 :{{reverse}}
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{ 
                msg:'computed计算属性',
                info:''
            },
            computed:{
                reverse(){
                    return this.info.split('').reverse().join('')
                }
            }
        })
    </script>

直接省略get,将:换成()后接{}即可,简写和完整写法对比

 // 简写
                reverse(){
                    return this.info.split('').reverse().join('')
                },
                // 完整写法
                reverse:{
                    get(){
                        return this.info.split('').reverse().join('')
                    }
                }

注意,简写后和methods中的函数方法写法相同,但这不是函数方法,这是计算属性

watch侦听属性

侦听属性变化

语法格式

watch:{
                //可以监视多个属性
                //监视哪个属性,直接写属性名字即可
                //可以监视Vue的原有属性,也可以监视计算属性
                num:{
                    //固定写法,方法名必须叫handler
                    //当被监视的属性发生变化时,handler就会自动调用一次
                    //handler方法有两个参数,前一个参数代表属性值改变后的新值,后一个参数代表属性值改变之前的旧值
                    handler(newValue,oldValue){
                        console.log(newValue,oldValue);
                    }
                }
            }

watch侦听属性中的this指向

 watch:{
                //可以监视多个属性
                //监视哪个属性,直接写属性名字即可
                //可以监视Vue的原有属性,也可以监视计算属性
                num:{
                    //固定写法,方法名必须叫handler
                    //当被监视的属性发生变化时,handler就会自动调用一次
                    //handler方法有两个参数,前一个参数代表属性值改变后的新值,后一个参数代表属性值改变之前的旧值
                    handler(newValue,oldValue){
                        console.log(this === vm);
                    }
                }
            }

由此可知,watch中的this也是指向vue实例对象的

watch深度监视

如何侦听对象呢?

例:侦听a对象里面的b

<div class="app">
        <h1>{{msg}}</h1>
        <input type="text" v-model="a.b">
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'watch侦听属性',
                a:{
                    b:0
                }
                
            },
            watch:{
                //可以监视多个属性
                //监视哪个属性,直接写属性名字即可
                //可以监视Vue的原有属性,也可以监视计算属性
                'a.b':{
                    //固定写法,方法名必须叫handler
                    //当被监视的属性发生变化时,handler就会自动调用一次
                    //handler方法有两个参数,前一个参数代表属性值改变后的新值,后一个参数代表属性值改变之前的旧值
                    handler(newValue,oldValue){
                        alert('111')
                    }
                }
            }
        })
    </script>

侦听这种嵌套的需要加上" ",原本就是有的,只是省略了,当侦听这种嵌套关系时,需要加上" ".

如果更深层次的嵌套,是否需要一直“...”下去呢?

不需要,vue给我提供了deep属性

deep:true(默认是false),当deep:true时,代表开启了深度监视,只需要监视对象便可监听该对象内的所有属性

 watch:{
                //可以监视多个属性
                //监视哪个属性,直接写属性名字即可
                //可以监视Vue的原有属性,也可以监视计算属性
                a:{
                    deep:true,
                    //固定写法,方法名必须叫handler
                    //当被监视的属性发生变化时,handler就会自动调用一次
                    //handler方法有两个参数,前一个参数代表属性值改变后的新值,后一个参数代表属性值改变之前的旧值
                    handler(newValue,oldValue){
                        alert('111')
                    }
                }
            }

watch的简写

原:

 watch:{
                
               a:{
                handler(){
                    console.log('监听到了');
                }
               }
            }

简写:

简写的条件是,不使用深度监视及其他的任何属性

 watch:{
                
               a(){
                console.log('监听到了');
               }
            }

watch和computed如何选择

  • 当computed和watch都能完成某个功能时,优先选择computed
  • 当程序中采用异步的方式时,只能使用watch

例:比较大小

先使用watch侦听属性

<div class="app">
        <h1>{{msg}}</h1>
        <button @click="add1">+1</button><br>
        <button @click="add2">+1</button><br>
        num1:{{num1}}<br>
        num2:{{num2}}<br>
        比较结果:{{daxiao}}
    </div>
<script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'computed和watch的选择',
                num1:1,
                num2:1,
                daxiao:""
            },
            methods:{
                add1(){
                    return this.num1++
                },
                add2(){
                    return this.num2++
                }
            },
            watch:{
                num1(){
                    if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                },
                num2(){
                    if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                },
            }
        })
    </script>

可以完成该功能

使用computed计算属性

<script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'computed和watch的选择',
                num1:1,
                num2:1,
                daxiao:""
            },
            methods:{
                add1(){
                    return this.num1++
                },
                add2(){
                    return this.num2++
                }
            },
            computed:{
                daxiao(){
                    if(this.num1 == this.num2){
                        return this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        return this.num1+'>'+ this.num2
                    }else {
                        return this.num1+'<'+this.num2
                    }
                }
            },
        })
    </script>

也能完成该功能,此种情况下选择computed计算属性

异步情况下

computed

 computed:{
                daxiao(){
                    setTimeout(()=>{
                        if(this.num1 == this.num2){
                        return this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        return this.num1+'>'+ this.num2
                    }else {
                        return this.num1+'<'+this.num2
                    }
                    },3000)
                }
            },

无法完成比较大小的功能

这是因为,在异步情况下的箭头函数由谁调用,this就指向谁,这里的是由javascript引擎调用的,return的时候也是把值返回给javascript引擎

watch

 watch:{
                num1(){
                    setTimeout(()=>{
                        if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                    },2000)
                },
                num2(){
                    setTimeout(()=>{
                        if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                    },2000)
                },
            }

在异步情况下,watch可以完成该功能

watch中异步中箭头函数和普通函数this指向

分别在箭头函数以及普通函数中打印this

 watch:{
                num1(){
                    setTimeout(()=>{
                        console.log(this);
                        if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                    },2000)
                },
                num2(){
                    setTimeout(function(){
                        console.log(this);
                        if(this.num1 == this.num2){
                        this.daxiao= this.num1 +'='+ this.num2
                    }else if(this.num1 > this.num2){
                        this.daxiao= this.num1+'>'+ this.num2
                    }else {
                        this.daxiao= this.num1+'<'+this.num2
                    }
                    },2000)
                },
            }

可以看出,在箭头函数中,this是指向Vue实例的,反而普通函数中的this指向window

在箭头函数中,this之所以指向Vue实例是因为,箭头函数是没有this,是继承过来的,那么在异步中,该函数是被Vue实例管理的num1调用的,所以this是指向Vue实例的

在普通函数中,this指向调用者,settimeout异步是window调用的,所以this是指向window的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1221030.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CTFd-Web题目动态flag

CTFd-Web题目动态flag 1. dockerhub注册2. dockerfile编写3. 上传到docker仓库4. 靶场配置5. 动态flag实现 1. dockerhub注册 想要把我们的web题目容器上传到docker仓库中&#xff0c;我们需要dockerhub官网注册一个账号&#xff0c;网址如下 https://hub.docker.com/2. dock…

Android Glide加载transform CenterCrop, CircleCrop ShapeableImageView圆形图并描边,Kotlin

Android Glide加载transform CenterCrop, CircleCrop ShapeableImageView圆形图并描边&#xff0c;Kotlin import android.os.Bundle import androidx.appcompat.app.AppCompatActivity import com.bumptech.glide.load.resource.bitmap.CenterCrop import com.bumptech.glide.…

基于ssm+vue设备配件检修管理系统

摘要 随着工业设备的日益复杂和多样化&#xff0c;设备配件的检修管理成为保障生产运行和设备寿命的关键环节。本研究基于SSM框架&#xff08;Spring Spring MVC MyBatis&#xff09;&#xff0c;致力于设计和实现一套全面、高效的设备配件检修管理系统。该系统不仅能够提高设…

从0开始学习数据结构 C语言实现 1.前篇及二分查找算法

一、前篇 1、什么是数据结构&#xff1f; 数据结构是带有结构特性的数据元素的集合&#xff0c;它研究的是数据的逻辑结构和数据的物理结构以及它们之间的相互关系 2、时间复杂度与空间复杂度 大O符号是用于描述函数渐进行为的数学符号 常用函数的增长表 阶乘O(n!) > 指数…

常见面试题-MySQL软删除以及索引结构

为什么 mysql 删了行记录&#xff0c;反而磁盘空间没有减少&#xff1f; 答&#xff1a; 在 mysql 中&#xff0c;当使用 delete 删除数据时&#xff0c;mysql 会将删除的数据标记为已删除&#xff0c;但是并不去磁盘上真正进行删除&#xff0c;而是在需要使用这片存储空间时…

【原创】java+swing+mysql校园活动管理系统设计与实现

前言&#xff1a; 本文介绍了一个校园活动管理系统的设计与实现。该系统基于JavaSwing技术&#xff0c;采用C/S架构&#xff0c;使用Java语言开发&#xff0c;以MySQL作为数据库。系统实现了活动发布、活动报名、活动列表查看等功能&#xff0c;方便了校园活动的发布和管理&am…

如何合理估算 Java 线程池大小

前 言 Java 中的线程创建会产生显著的成本。创建线程会消耗时间&#xff0c;增加请求处理的延迟&#xff0c;并且涉及 JVM 和操作系统的大量工作。为了减轻这些开销&#xff0c;线程池发挥了作用。 在本文中&#xff0c;我们将深入研究确定理想线程池大小的艺术。经过微调的线…

【数据结构】栈与队列的实现

栈与队列是数据结构中重要的结构&#xff0c; 可以用于解决一些题目 模拟实现时可以增加对于这些结构的理解&#xff0c;也可以巩固我们的语言水平&#xff0c;解决某些题目也会有很好的效果 话不多说 目录 栈的实现结构体的定义&#xff1a;初始化栈:压栈&#xff1a;出栈&am…

leetcode栈和队列三剑客

用队列实现栈 队列是先进先出的&#xff0c;而栈是只能在栈顶进行出栈和入栈&#xff0c;那我们这道题要用队列来实现栈的话&#xff0c;这里给的思路是两个队列&#xff0c;因为两个队列的话就可以相互导数据&#xff0c;比如我们来实现这个题目的push函数&#xff0c;我们的栈…

面试其他注意事项

面试其他注意事项 一、面试反问 这个岗位的日常工作和主要职责是什么&#xff1f;咱们这边主要负责什么业务&#xff0c;用到了哪些技术呢&#xff1f;对于我们校招生有没有培养体系呢&#xff1f;脱产培训&#xff0c;还是边工作边熟悉&#xff1f;会有导师带嘛&#xff1f;…

飞书开发学习笔记(八)-开发飞书小程序Demo

飞书开发学习笔记(八)-开发飞书小程序Demo 一.小程序开发概述 1.1 小程序开发概述 飞书开发文档中查看&#xff1a;小程序开发概述 飞书小程序是指可以运行在飞书客户端中的小程序&#xff0c;小程序的一套代码可以适配 Android、iOS、PC 多平台&#xff0c;且用户体验与飞书…

计算机多媒体

1&#xff0c;媒体、多媒体 2&#xff0c;体系结构 3&#xff0c;采样、编码

公寓水电管理系统

springbootmybatisthymeleaf 这次练习是尝试将layer与系统结合起来&#xff0c;将新增、修改、删除都和弹窗结合起来。 一、需求分析 二、数据库 三、模块 1、登录页面 哈哈哈&#xff0c;之前做的登录页面都好丑&#xff0c;这是目前做的最好看的一次了。 超级管理员&…

卷积神经网络(CNN)鲜花的识别

文章目录 前期工作1. 设置GPU&#xff08;如果使用的是CPU可以忽略这步&#xff09;我的环境&#xff1a; 2. 导入数据3. 检查数据 二、数据预处理1. 加载数据2. 可视化数据3. 再次检查数据4. 配置数据集 三、构建CNN网络四、编译五、训练模型六、模型评估 前期工作 1. 设置GP…

串口通信原理及应用

Content 1. 前言介绍2. 连接方式3. 数据帧格式4. 代码编写 1. 前言介绍 串口通信是一种设备间非常常用的串行接口&#xff0c;以比特位的形式发送或接收数据&#xff0c;由于成本很低&#xff0c;容易使用&#xff0c;工程师经常使用这种方式来调试 MCU。 串口通信应用广泛&a…

【教3妹学编程-算法题】高访问员工

2哥 : 3妹&#xff0c;今天周五怎么还下班这么晚啊&#xff1f;这么晚了才回来 3妹&#xff1a;项目快上线了&#xff0c; 最近事情比较多&#xff0c;再累也要干&#xff0c; 撸起袖子加油干&#xff01; 2哥 : 辛苦辛苦&#xff0c; 哎&#xff0c;你看到王自如格力那个采访了…

叮!您收到了一封来自达坦科技的Hackthon邀请函

DatenLord Hackathon 2023正式启动&#xff01;达坦科技基于其跨云分布式文件系统DatenLord项目&#xff0c;结合AI大模型时代背景&#xff0c;搭建了擂台&#xff0c;在此正式向您发出邀约&#xff01; 本次大赛赛题深刻有趣&#xff0c;奖品丰厚多样&#xff0c;借此机会您不…

034、test

之——全纪录 目录 之——全纪录 杂谈 正文 1.下载处理数据 2.数据集概览 3.构建自定义dataset 4.初始化网络 5.训练 杂谈 综合方法试一下。 leaves 1.下载处理数据 从官网下载数据集&#xff1a;Classify Leaves | Kaggle 解压后有一个图片集&#xff0c;一个提交示…

JavaWeb[总结]

文章目录 一、Tomcat1. BS 与 CS 开发介绍1.1 BS 开发1.2 CS 开发 2. 浏览器访问 web 服务过程详解(面试题)2.1 回到前面的 JavaWeb 开发技术栈图2.2 浏览器访问 web 服务器文件的 UML时序图(过程) &#xff01; 二、动态 WEB 开发核心-Servlet1. 为什么会出现 Servlet2. 什么是…

【C++】模版-初阶

目录 泛型编程--模版 函数模版 类模版 泛型编程--模版 函数模版 如何实现一个通用的交换函数呢?void Swap(int& left, int& right){int temp left;left right;right temp;}void Swap(double& left, double& right){double temp left;left right;righ…