前端菜鸡学习日记 -- computed和watch的用法

2024-06-17 15:04

本文主要是介绍前端菜鸡学习日记 -- computed和watch的用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.computed:

2.watch:


哈喽哇大家,又是新的一周,因为一些特殊的原因,所以目前是比较闲的,就趁机多学习一点东西把,这些学习日记就是学习中的笔记咯,流水账日记则是工作中遇到的实际的问题,大家可以按需查看~  (侧重于vue3)

------------------------------------

1.computed:

语法:const 变量名  = computed(() => { return })

步骤:从vue中导入‘computed’函数

           在setup函数中,使用computed函数,传入一个喊出,函数返回计算好的数据

           最后,setup函数返回一个对象,包含该计算属性数据即可,然后模板内使用

例子:

import { computed , ref } from 'vue' //导入const list = ref(2,5,8,9,10,3) //定义一个list变量//需求:计算list中大于5的数据
const newList = computed(() =>{return list.value.filter((item) =>item>5)
})

通过以上的代码即可计算完成,想要查看的话可以输出到页面中查看,例如:

<ul>
<li v-for = 'item in newList ' :key = 'item'> {{ item }} </li>
</ul>

当然插看的方式不只是这一种,这种作为例子查看简单直接

如果给list一个按钮,并且点击的时候给一个100内的随机数组,就会发现,当新增的随机数是大于5的list更改的同时newList也会进行变化

点击事件:
const changeList = () =>{list.value.push( Math.random()*100+10)
}按钮:
<button>新增随机数</button>

就像截图所示那样,所以可以看出,computed是依赖list变量的计算结果,一旦list变化,那么newList也会进行变化,即有缓存

特点:

1.有缓存

2.不支持异步

3.一般用于计算

----------------------------------------

2.watch:

语法1:watch (变量,() => {})

语法2:watch([变量1,变量2,....],() => {})

步骤:同computed的步骤

用法:可以监听一个或者多个,也可以监听对象中的一个属性也可以配置深度监听

语法1和2例子:

const count = ref(0)  //定义一个变量
const bool = ref(false)watch(count,(newval,oldval) => {console('count变化了', newval,oldval)
})  //按照语法进行一个新的值和酒的值变化的输出想要监听多个变量的话就是 前边变量部分用中括号括起来
wathc([count, bool] ,( newval,oldval ) => {console(newval,oldval)  //可以一起监听到两个变量
})

深度监听:

-----
深度监听:
const obj ref({name:'小明',age:18
})watch(obj,(newval,oldval) => {console.log(newval.oldval)
},{deep:true, //深度监听immediate:true  //页面加载后立即执行一次监听
})给个按钮
<button @click = obj.age++> 年龄增加 </button>
需要深度监听才可以,否则就是只有页面变化,但是监控不到 

deep:true  -- 开启深度监听

immediate:true   -- 立即监听,加载刷新了立即执行一次

特点:

1.没有缓存

2.支持异步

2.主要是监测数据的变化,不做计算,没有返回

这篇关于前端菜鸡学习日记 -- computed和watch的用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1069774

相关文章

SpringBoot3.4配置校验新特性的用法详解

《SpringBoot3.4配置校验新特性的用法详解》SpringBoot3.4对配置校验支持进行了全面升级,这篇文章为大家详细介绍了一下它们的具体使用,文中的示例代码讲解详细,感兴趣的小伙伴可以参考... 目录基本用法示例定义配置类配置 application.yml注入使用嵌套对象与集合元素深度校验开发

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Python中的getopt模块用法小结

《Python中的getopt模块用法小结》getopt.getopt()函数是Python中用于解析命令行参数的标准库函数,该函数可以从命令行中提取选项和参数,并对它们进行处理,本文详细介绍了Pyt... 目录getopt模块介绍getopt.getopt函数的介绍getopt模块的常用用法getopt模

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的