首页 > 其他分享 >computed计算属性及方法对比和循环遍历统计以及watch和watchEect监听的用法

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

时间:2024-09-01 13:52:28浏览次数:19  
标签:computed watchEect watch 选中 页面 我们 属性

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监听器的认知和用法。

标签:computed,watchEect,watch,选中,页面,我们,属性
From: https://blog.csdn.net/dengshuweng/article/details/141728841

相关文章

  • Lecture 06 Real-time Environment Mapping (Precomputed Radiance Transfer)
    Lecture06Real-timeEnvironmentMapping(PrecomputedRadianceTransfer)Shadowfromenvironmentlighting通常情况下要实时渲染非常困难在不同观察方向上Asamany-lightproblem:CostofShadowMapislinearlyto#lightAsasamplingproblem:Visibility项V会......
  • .NET 开源实时监控系统 - WatchDog
    目录前言项目介绍功能特点项目技术栈工作原理1、支持.NET版本2、下载源码安装与配置1、WatchDog安装2、WatchDog服务注册3、添加异常记录器4、设置自动清除日志(可选)5、设置日志记录到外部数据库(可选)6、设置访问日志的账号密码7、配置说明和示例8、记录消息/......
  • .NET 开源实时监控系统 - WatchDog
    前言在平时的开发中随着我们系统应用不断地迭代变的复杂,对应用的实时监控变得越来越重要。实时监控不仅可以帮助我们快速定位问题,还能在出现问题时及时采取措施,减少业务中断的时间。本文将介绍一个名为WatchDog的.NET开源实时应用监控系统,它可以帮助我们轻松实现对.NET应用的实......
  • Zookeeper的watch机制是如何工作的?
    ZooKeeperWatch概述ZooKeeperWatch机制类似于Java设计模式中的观察者模式或者监听模式,唯一的不同是不再基于线程间通信,而是基于进程间通信。ZooKeeperWatch机制是指,客户端在所有的读命令上告知服务端:这个节点或者子节点变化时通知我,具体来说,支持的写操作有:getData......
  • vue3 响应式 API:watch()、watchEffect()
    watch()基本概念watch()用于监视响应式数据的变化,并在数据变化时执行相应的回调函数。可以监视单个响应式数据、多个响应式数据的组合,或者一个计算属性。返回值返回一个函数,调用这个函数可以停止监视。特点watch()默认是懒侦听的,即仅在侦听源发生变化时才执行回调函......
  • vue3 响应式 API:computed()
    介绍基本概念:computed()接收一个getter函数或者一个包含getter和setter函数的对象作为参数,并返回一个基于原始响应式数据计算得到的新的响应式数据对象。计算属性的值会根据其依赖的响应式数据自动更新,当依赖的数据发生变化时,计算属性的值也会自动重新计算。返......
  • vue3+watch
    watch—vue3是一个惰性,所谓惰性,就是被动的去进行调用,而不是主动的去进行触发,可以通过使用immediate来等进行立即执行调用如何在初始阶段进行触发呢?了解到watch中的参数watch(参数一:监听的数据,参数二:回调函数()=>{编辑代码},参数三:option?用于执行一些配置选项)参数一:是在se......
  • 021、Vue3+TypeScript基础,使用watchEffect全自动监视修改的对象
    01、App.vue代码如下:<template><divclass="app"><h2>{{title}}</h2><!--使用了ref来获取子组件的属性--><Person/></div></template><scriptlang="ts"setupname="App"......
  • 019、Vue3+TypeScript基础,使用watch监视对象数据时,如何监控整个对象或单独监控对象某
    1、App.vue代码如下:<template><divclass="app"><h2>{{title}}</h2><!--使用了ref来获取子组件的属性--><Person/></div></template><scriptlang="ts"setupname="App"&......
  • 020、Vue3+TypeScript基础,使用watch监视对象数据时,监控多种属性的修改
    01、App.vue代码如下:<template><divclass="app"><h2>{{title}}</h2><!--使用了ref来获取子组件的属性--><Person/></div></template><scriptlang="ts"setupname="App"......