computed计算属性及方法对比和循环遍历统计以及watch和watchEect监听的用法

news2024/9/22 9:33:52

1.computed计算属性及方法对比

1.了解computed计算属性和用法

在我们的一些应用中可以看的应用会给我们提供一些计算类的功能比如取名,它会给你提供两个输入框,然后在你给这两个输入框输入值的时候会在下方生成你输入这个两个值的结合值,就比如你先输入了一个姓氏,然后输入一个名,下方就会生一个姓名。

我们先在uni-app里面创建一个页面然后给其一些组件和css属性等

页面示例:

当我们分别给两个赋予值时

会发现我们的两个属性在下方结合在了一起,是因为我们调用了{{}}给两个输入框的值冰并和在了一起。

我们也可以使用我们的函数来完成。

保存好我们修改的代码后去页面看一下我们的效果是否还和之前的效果一致。

但是我们右击检查页面的时候,会发现我们调用了三次我们的函数就运行了三次,控制台输入是因为我们在函数里面添加了console.log("函数计算"),来查看我们执行了多少次我们的函数。

但是如果我想要调用了多次,却只需要执一次我们的方法时可以使用我们的computed来实现。

保存好我们的运行结果之后去页面查看。

这个方法可以帮助我们节省性能,在需要进行多次相同的运算是需要使用此方法可以大大节约我们的性能。

在使用我们的computed的时候需要注意不要更改值。

我们不可以修改我们的computed的值否则会发生错误。

2.computed的循环计算

1.computed的认知和用法

我们在又多个数据的情况下需要计算他们的总值时可以使用我们的computed的循环计算来完成。

先创建我们的页面,示例:

添加了以上的代码后在我们的页面显示的地方使用checkbox-group包裹住,并且添加上@change给其赋予一个点击方法,我们吗可以从点击方法里面获取我们的值。

我们可以在选中产品的下方添加一个显示我们数组的值。

添加好了之后到页面中查看我们的效果。

这个时候我们可以来给我们的数组新增一个是否被选中的属性,我们默认给其值为false,在checkbox里面添加一个:checked属性在这个属性里面调用我们的是否被选中的属性。

我们将我们整个的数组放在一个view里面到页面中展示我们的数组,观察我们的数组是否被选中且,改为了true。

这样我们就可以根据这个属性来找到我们的价格,从而完成我们的计算我们选中的总共价值是多少了。

我们在下放创建了一个函数,将我们的总价值改为我们创建的函数,根据我们的是否被选中的属性,从而计算出我们的总价值,filter是根据我们依靠什么属性来作为依据,reduce是来定义我们的总价值,一个属性适总价另一个是这个被选中的对象里面我们所定义的price属性,这个依靠我们的遍历来实现的,将我们的所以内容遍历完成之后才会给出我们的总金额。

这个就是我们的computed的循环遍历数组的作用,可以依靠遍历来实现我们的取总。

3.watc和watchEect监听器的用法

1.了解我们的watch的基本用法

我们如果需要在改变我们的值的时候将我们新改变的值获取可以使用我们的watch监听器,这个监听器的作用是我们在改变值的时候获取到我们改变的新值和老值。

如果我们只需要我们新输入的值,可以将我们的新值后面的参数去掉 ,只保留我们的新值。我们将我们的变量该为数组,然后只取我们指定的值。

没有输出我们刚刚改变的新值是因为我们的取值范围并没有确地下来,所以我们需要将我们的watch里面的取值范围改成我们的指定属性即可。

我们可以以使用我们的另一个方法来实现,这个需要我们的deep也就是深层监听,不过这个监听在我们的官网里面说明会影响我们的性能,可以去官网自己了解一下。在使用我们的深层监听的时候也可以使用我们的立即执行immediate这个作用是我们一进去就会执行一次。

链接:侦听器 | Vue.js (vuejs.org)

我们改为之前的那个项目将我们的计算器改为我们的watch

我们也可以使用我们的watchEffect来实现我们改变其中一个值的时候,就会同步出我们的两个输入框里面的值。

所以我们的watchEffect就是我们在对页面的值改变是获取我们的被改变页面的所有值。

这个以上就是我们的watch和watchEffect监听器的认知和用法。

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

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

相关文章

Java使用类加载器解决类冲突,多版本jar共存

Java使用类加载器解决类冲突 1、案例说明2、打包新版本POI并将要调用的方法封装2.1、POM文件2.2、封装的方法 3、要使用多个POI版本的项目3.1、打包前面的项目生成一个jar包3.1、POM文件3.2、类加载器代码3.3、Jar加载工具3.4、最终调用 1、案例说明 项目中已经有了一个旧版本…

【后端开发】PHP、go语言、Java、C++、Linux开发等急招中......

本周高薪急招后端开发岗位推荐,PHP、go语言、Java、C、Linux开发等岗位都在热招,月薪最高35K,还不快来!! 抓紧投递,早投早入职! 👇点击职位名称查看详情👇 PHP 薪资&…

Leetcode每日刷题之102.二叉树的层序遍历

1.题目解析 本题是关于二叉树的层序遍历,不过这里的难点是如何将每一层的数据存储在数组并将整体存储在一个二维数组中,具体的算法原理我们在下面给出 2.算法原理 关于将每层数据分别存储在不同数组中,我们可以定义一个levelSize变量来存储栈…

网络编程(TCP+网络模型)

【1】TCP 初版服务器 #include <stdio.h> #include <sys/types.h> /* See NOTES */ #include <sys/socket.h> #include <netinet/in.h> #include <netinet/ip.h> #include <unistd.h> #include <arpa/inet.h> #include <string.h…

【学习笔记】SSL/TLS如何运用加密工具

一、前文回顾&#xff1a; 1、SSL/TLS有3个目的&#xff0c;分别由不同密码学工具提供 Confidentiality&#xff08;保密性&#xff09;&#xff1a;数据只有Client和Server才能访问&#xff0c;由Encryption&#xff08;加密&#xff09;所提供Integrity&#xff08;完整性&…

【话题讨论】VS Code:倍增编程动力,实现效率飞跃

目录 引言 一、详情介绍 功能特点 使用场景 提高工作效率 二、效率对比 2.1 高度可定制性与丰富的插件生态 2.2 智能的代码补全与导航 2.3 内置的调试器与版本控制集成 2.4 轻量级与跨平台 2.5 选择合适工具的重要性 2.6 实际案例或数据展示 三、未来趋势 3.1 编…

iOS——Block与内存管理

需要内存管理的情况 1、对象类型的auto变量。 2、引用了 __block 修饰符的变量。 三种block类型 全局类型 &#xff08;NSGlobalBlock&#xff09; 如果一个block里面没有访问普通局部变量(也就是说block里面没有访问任何外部变量或者访问的是静态局部变量或者访问的是全局…

FPGA开发:可编程逻辑器件概述

PLD 1、什么是PLD&#xff1f; PLD指Programmable Logic Device&#xff0c;翻译为"可编程逻辑器件"。是20世纪70年代发展起来的一种新的集成电路&#xff0c;是一种半定制的集成电路。 PLD具有逻辑功能实现灵活。集成度高、处理速度快的特点。 PLD就像是一个可定…

【Vue】pnpm创建Vue3+Vite项目

初始化项目 &#xff08;1&#xff09;cmd切换到指定工作目录&#xff0c;运行pnpm create vue命令&#xff0c;输入项目名称后按需安装组件 &#xff08;2&#xff09;使用vs code打开所创建的项目目录&#xff0c;Ctrl~快捷键打开终端&#xff0c;输入pnpm install下载项目…

IDEA运行Java程序提示“java: 警告: 源发行版 11 需要目标发行版 11”

遇到这个提示一般是在pom.xml中已经指定了构建的Java版本环境是11例如(此时添加了build插件的情况下虽然不能直接运行代码但是maven是可以正常打包构建)&#xff1a; <build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><…

Vue初学-简易计算器

最近在学习Vue的指令&#xff0c;做了一个简易计算器&#xff0c;比较适合刚入门的人参考学习。用到的知识点有&#xff1a; 1.插值表达式 2.v-model&#xff0c;双向绑定、-、*、/、**等操作符 3.v-show&#xff0c;控制操作数2是否显示&#xff0c;乘方时不显示操作数2 4.met…

‌软媒市场—‌软媒市场自助发布平台引领数字营销新风尚

在当今这个信息爆炸的时代,数字营销已经成为企业推广品牌、提升知名度的关键手段。而在众多数字营销工具中,‌软媒市场自助发布平台以其独特的优势脱颖而出,成为众多企业的首选。今天,我们就来深入探讨一下软文媒体自助发布平台如何在软媒市场中发挥重要作用,以及其背后的5万家…

FRP代理(TCP通信)实验

攻击机器---公网机器&#xff08;FRP服务端&#xff09;-TCP传输rdp内容--内网机器&#xff08;FRP客户端&#xff09;--内网本地&#xff08;RDP服务&#xff09; FRP版本&#xff1a;0.49.0 公网IP&#xff08;FRP服务端&#xff09;&#xff1a;192.168.254.131 内网&…

Mindspore 初学教程 - 4. 数据集 Dataset

数据是深度学习的基础&#xff0c;MindSpore 提供基于 Pipeline 的 数据引擎&#xff0c;通过数据集 数据集&#xff08;Dataset&#xff09; 和 数据变换&#xff08;Transforms&#xff09; 实现高效的数据预处理。其中 Dataset 是 Pipeline 的起始&#xff0c;用于加载原始数…

# centos7 安装 mysql

centos7安装mysql 1、添加 mysql 官方 yum 存储库 wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpmrpm -ivh mysql80-community-release-el7-3.noarch.rpm2、使用Yum安装MySQL服务器&#xff1a; sudo yum install mysql-server3、启动MySQL服务…

Redis集群技术2——redis基础

Redis安装 Redis 的安装相对简单&#xff0c;无论是 Windows、Linux 还是 macOS 系统&#xff0c;都有相应的安装方法。以下是针对不同操作系统的 Redis 安装简述。 1. Linux 系统安装 Redis 在 Linux 系统中安装 Redis 通常有多种方式&#xff0c;这里以 Ubuntu 和 CentOS 为…

配置阿里云千问大模型--环境变量dashscope

1 开通百炼 首先要进入到阿里云平台&#xff0c;然后进入百炼平台。 2 获取API-KEY 进入之后再右上角可以查看到自己的API-KEY&#xff0c;这个东西就是需要配置在环境变量里的。 点击查看就可以获取 3 配置DASHSCOPE环境变量 如果使用dashscope来进行千问大模型的API对…

速度滞后补偿控制

这里介绍的速度滞后补偿控制和我们前面介绍的前馈控制有所区别&#xff0c;前馈控制的前提是能够获取位置参考指令的速度或加速度信号。在无法获取位置参考指令的上述性息的前提下&#xff0c;我们可以采用速度滞后补偿控制提高机电伺服控制系统动态跟踪精度。前馈控制的一些基…

2024社区版IDEA springboot日志输出颜色

IDEA版本&#xff1a;IntelliJ IDEA 2024.1.4 (Community Edition) 1、纯白色终端 2、彩色终端 3、配置过程 1、打开配置 2、选择启动类 3、点击修改选项&#xff0c;勾选虚拟机选项 4、在虚拟机选项框输入以下代码 -Dspring.output.ansi.enabledALWAYS5、应用确定&#xff0…

NLP从零开始------18.文本中阶处理之序列到序列模型(3)

4.3 其他解码问题和解码技巧 贪心解码和束解码只是最基础的解码方法&#xff0c;其解码结果会出现许多问题。这里主要介绍3种常见问题&#xff0c;并简单介绍解决方案。 4.3.1 重复性问题 有时我们会发现序列到序列模型不断重复的输出同一个词。一个解决方案是解码时在所预测的…