(八)Vue之计算属性

news2024/11/18 17:32:45

文章目录

  • 插值语法实现
  • methods实现
  • 计算属性实现
    • 计算属性简写

Vue学习目录

上一篇:(七)Vue之事件处理

先看一个需求:提供两个输入框,一个输入姓,一个输入名,在下面展示全名。
在这里插入图片描述

插值语法实现

页面使用插值语法,分别展示姓和名

	<div id="root">
       姓:<input type="text" v-model="firstName"><br>
       名:<input type="text" v-model="lastName"><br>
       全名:<span>{{firstName}}-{{lastName}}</span>
    </div>
    <script type="text/javascript">
        Vue.config.productionTip = false//阻止 vue 在启动时生成生产提示。
        new Vue({
            el:'#root',
            data:{
                firstName:'张',
                lastName:'三'
            }
        });
    </script>

效果:
请添加图片描述
局限性:对于当前案例来说,插值语法实现是可行的,当需求比较多的时候,页面就需要很多的插值语法,可读性会变差

methods实现

因为插值语法里面可以写js表达式,我们可以把需求封装成一个函数,通过插值语法调用。

	<div id="root">
       姓:<input type="text" v-model="firstName"><br>
       名:<input type="text" v-model="lastName"><br>
       全名:<span>{{fullName()}}</span>
    </div>
    <script type="text/javascript">
        Vue.config.productionTip = false//阻止 vue 在启动时生成生产提示。
        new Vue({
            el:'#root',
            data:{
                firstName:'张',
                lastName:'三'
            },
            methods:{
                fullName(){
                    console.log('fullName被调用')
                    return this.firstName + '-' + this.lastName
                }
            }
        });
    </script>

效果:
在这里插入图片描述
一开始页面加载就调用,往后每改变一次,就调用一次

计算属性实现

定义:要用的属性不存在,要通过已有属性计算得来。并且在模板中放入太多的逻辑会让模板过重且难以维护。对于任何复杂逻辑,应当使用计算属性。计算属性关键词: computed。

原理:底层借助了Objcet.defineproperty方法提供的getter和setter。

  • setter:当计算属性被修改时调用。
  • getter:当有人读取fullName时,get就会被调用,且返回值就作为fullName的值。
    • 1.初次读取计算属性时
    • 2.所依赖的数据发生改变时
<div id="root">
        姓:<input type="text" v-model="firstName"><br>
        名:<input type="text" v-model="lastName"><br>
        全名:<span>{{fullName}}</span><br>
        全名:<span>{{fullName}}</span><br>
        全名:<span>{{fullName}}</span><br>
    </div>

    <script type="text/javascript">
        Vue.config.productionTip = false//阻止 vue 在启动时生成生产提示。
        const vm = new Vue({
            el:'#root',
            data:{
                firstName:'张',
                lastName:'三'
            },
            computed:{
                fullName:{
                    get(){
                        console.log('get被调用')
                        return this.firstName + '-'  + this.lastName
                    },
                    set(value){
                        console.log('set被调用', value)
                        const arr = value.split('-')
                        this.firstName = arr[0]
                        this.lastName = arr[1]
                    }
                }
            }
        });
    </script>

效果:我们发现页面不管使用多少次,getter只会被调用一次
在这里插入图片描述
清除控制台,在输入框输入数据,发现往后所依赖的数据发生改变是,getter就会被调用,改变一次调用一次
在这里插入图片描述
控制台输入vm,发现计算属性最终会出现在vm身上,并且有对应的setter和getter
请添加图片描述
请添加图片描述
改变vm里的计算属性,发现先是调用了setter方法,我们在setter方法里面改变了计算属性所依赖的数据,所以又调用了getter方法。
在这里插入图片描述
与methods对比:两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。
与methods实现相比,计算属性内部有缓存机制(复用),效率更高,调试方便。

计算属性简写

一旦确定计算属性是被读取,而不是被修改,计算属性就可以被简写。
怎么简写,不用把计算属性写成配置项了,可以简写成函数。
例如上述例子可以进行简写:简写就只有getter作用,没有setter

	computed:{
                //完整写法
                /*fullName:{
                    get(){
                        console.log('get被调用')
                        return this.firstName + '-'  + this.lastName
                    }
                }*/
                //简写
                fullName(){
                    console.log('get被调用了')
                    return this.firstName + '-' + this.lastName
                }
            }

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

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

相关文章

vue3中的四种插槽的介绍-保证让你看看的明明白白!

插槽 当组件中只有一个插槽的时候&#xff0c;我们可以不设置 slot 的 name 属性。 v-slot 后可以不带参数&#xff0c;但是 v-slot 在没有设置 name 属性的时候&#xff0c; 插槽口会默认为“default”。 插槽主要是在封装组件的时候去使用 注意点&#xff1a;v-slot 只能添加…

【操作系统】操作系统硬件组成和进程

硬件组成体系结构 1.为什么要学操作系统 从操作系统-网络-应用程序-存储等多方面诊断和优化。比如&#xff1a;接口突然响应慢、服务器内存、CPU占用率高、Redis、MySQL查询慢&#xff0c;怎末排查问题。 2.性能优化诊断方法论 &#xff08;1&#xff09;围绕两个点&#x…

第12章 初识消息队列(MessageQueuing)

1 Redis分布式缓存数据库结合“StackExchange.Redis”中间件实现消息队列(MessageQueuing) Redis分布式缓存数据库消息队列(MessageQueuing)队列的实现模式有&#xff1a; 1、【生产(Producter)】--【消费(Worker)】模式。 变种模式&#xff1a;【基于异步消息队列List lpush-b…

Zabbix部署agent2

客户端提前部署好 下载rpm环境 http://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-agent2-5.0.2-1.el7.x86_64.rpm安装 [rootvpn_server opt]# yum localinstall zabbix-agent2-5.0.2-1.el7.x86_64.rpm -y# 修改配置⽂件&#xff0c;启动zabbix-agent2# 在zabbix-serve…

代码随想录第二天

专题&#xff1a;数组 题目&#xff1a;有序数组的平方 给你一个按 非递减顺序 排序的整数数组 nums&#xff0c;返回 每个数字的平方 组成的新数组&#xff0c;要求也按 非递减顺序 排序。 示例 2&#xff1a; 输入&#xff1a;nums [-7,-3,2,3,11] 输出&#xff1a;[4,9,9,…

[附源码]JAVA毕业设计外卖点餐系统(系统+LW)

[附源码]JAVA毕业设计外卖点餐系统&#xff08;系统LW&#xff09; 项目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&…

有趣且重要的css知识合集(6)动态控制css伪元素【var()】

在vue里&#xff0c;js和css的属性可以随意控制&#xff0c;比如:class和:style&#xff0c;但是我们想要动态控制伪元素的属性该怎么做呢&#xff1f; 比如下图&#xff0c;右下角小圆圈就是通过伪元素定义上去的&#xff0c;那我们想要自由实现伪元素的显示和隐藏该怎么做呢…

如何使用 MySQL、Thymeleaf 和 Spring Boot 从数据库上传和下载多个文件

使用百里香叶的春季启动上传和下载示例。在本文中&#xff0c;我们将学习如何从数据库上传和下载文件。 上传和下载文件是任何应用程序的重要组成部分之一。众所周知&#xff0c;我们使用 Spring Boot 使开发过程变得简单。因此&#xff0c;在这里我们将创建一个示例来从数据库…

高通Ride开发包使用指南(1)

高通Ride开发包使用指南&#xff08;1&#xff09;1引言1.1目的1.2范围1.3术语2系统前提条件和设置2.1先决条件2.1.1硬件2.1.2 软件2.1.3其他所需软件&#xff1a;2.2布线和设置1引言 1.1目的 本文档面向高通公司Snapdragon Ride的用户™ 平台3.0&#xff08;Cetus&#xff0…

点击化学DBCO-PEG8-Benzylamine,二苯并环辛炔-PEG8-苄胺标记试剂

【中文名称】二苯并环辛炔-八聚乙二醇-苄胺 【英文名称】 DBCO-PEG8-Benzylamine 【CAS号】N/A 【分子式】C42H55N3O10 【分子量】761.91 【基团】DBCO基团 【纯度】95%(HPLC) 【规格标准】1g&#xff0c;5g&#xff0c;10g&#xff0c;包装灵活&#xff0c;可进行相应的封装。…

[附源码]JAVA毕业设计微留学学生管理系统(系统+LW)

[附源码]JAVA毕业设计微留学学生管理系统&#xff08;系统LW&#xff09; 项目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技…

【2022.12.08】备战春招Day3——每日一题 + 406. 根据身高重建队列

【每日一题】1812. 判断国际象棋棋盘中一个格子的颜色 题目描述 给你一个坐标 coordinates &#xff0c;它是一个字符串&#xff0c;表示国际象棋棋盘中一个格子的坐标。下图是国际象棋棋盘示意图。 如果所给格子的颜色是白色&#xff0c;请你返回 true&#xff0c;如果是黑色…

DataX 源码调试及打包

文章目录1、源码分析2、打包3、任务测试4、job配置详解Reader&#xff08;读插件&#xff09;Writer&#xff08;写插件&#xff09;通用配置前文回顾&#xff1a; 《DataX 及 DataX-Web 安装使用详解》 除了前文介绍的我们可以直接安装使用外&#xff0c;还可以下载源码打包&…

一文解决Kubernetes 的 API 流量查看器 - Kubeshark

一、Kubeshark 是什么&#xff1f; Kubeshark 由 2021 年 UP9 公司开源的 K8s API 流量查看器 Mizu 发展而来&#xff0c;试图成为一款 K8s 全过程流量监控工具。 Kubeshark 被叫做 kubernetes 的 API 流量查看器&#xff0c;它提供对进出 Kubernetes 集群内容器和 pod 的所有…

[附源码]JAVA毕业设计微服务的高校二手交易平台(系统+LW)

[附源码]JAVA毕业设计微服务的高校二手交易平台&#xff08;系统LW&#xff09; 项目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 …

多线程与高并发(14)——Executor框架(线程池基础)

一、简介 线程是什么&#xff0c;线程是一个任务的工作单元和执行单元。我们在用线程的时候知道&#xff0c;要创建线程&#xff0c;再执行线程。如果任务多的情况呢&#xff0c;会有大量的创建销毁线程的资源消耗&#xff0c;这时候就引入了线程池的概念。 JDK5开始&#xff…

使用Maven创建Servlet项目

创建Maven项目 点击FIle, 选择new ,选择Project… 选择Maven 然后点击next. 选择自己想要创建项目的目录.点击next 引入依赖 在pom.xml中添加servlet依赖. 先书写dependencies标签.然后在 Maven中央仓库 中找到servlet的依赖.复制填写进去. 这里是我常用的一个 Maven中央仓库…

TI Lab_SRR学习_3 速度扩展_2 interChirpProcessing_RangeDPU

RangeProcDSP共分为三步,如下图所示 transfers ADCBuf data through dataIn EDMA channels in ping/pong alternate order to FFT input scratch buffer - adcDataIn.Range FFT processing is done by using DSPlib and mmwavelib APIs. FFT input data is stored in input sc…

[附源码]计算机毕业设计JAVA中青年健康管理监测系统

[附源码]计算机毕业设计JAVA中青年健康管理监测系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM …

Python 实战分析某招聘网站数据分析岗位的招聘情况

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~ 今天案例难度指数: ☆☆☆ 准备 环境使用&#xff1a; Anaconda (python3.9) –>识别我们写的代码 开发工具&#xff1a; jupyter notebook –>代码编辑功能敲代码的工具 相关模块&#xff1a; seaborn pandas …