学习Vue3——Ref全家桶

news2025/1/10 21:27:21

参考地址

小满Vue3视频

ref

创造响应式对象

这样修改num的值是可以,但是页面展示不正常,因为这不是响应式的,无法被vue追踪

<template>
  <div>
    {{ num }}
  </div>
  <button @click="change">修改</button>
</template>

<script setup lang="ts">
let num = 1
const change = () => {
  num++
  console.log(`num:${num}`)
}
</script>

可以使用ref来包装这个值,完成响应
注意被ref包装之后需要.value 来进行赋值

<template>
  <div>
    {{ num }}
  </div>
  <button @click="change">修改</button>
</template>
<script setup lang="ts">
import { ref } from 'vue'
let num = ref(1)
const change = () => {
  num.value++
  console.log(`num:${num.value}`)
}
</script>

获取元素dom

<template>
  <div ref="dom" @click="getDom">我是dom</div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
const dom = ref<HTMLDivElement>()
const getDom = () => {
  console.log(dom.value?.innerText) // 我是dom
}
</script>

shallowRef

ref是深层次的响应,shallowRef是浅层次的比较 ,修改其属性是非响应式的

<template>
  <div>Ref: {{ title }}</div>
  <button @click="changeTitle">Ref按钮</button>
  <hr />
  <div>shallowRef:{{ header }}</div>
  <button @click="changeName">shallowRef按钮</button>
  <hr />
</template>
<script setup lang="ts">
import { ref, shallowRef } from 'vue'
let title = ref({ name: 'hello world' })
let header = shallowRef({ name: 'zs' })

const changeTitle = () => {
  title.value.name = 'I am coming'
}

const changeName = () => {
  header.value.name = 'ls'
  console.log(header) // 值已经改变,但是页面不会响应
}
</script>

修改value是可以被监听到的

const changeName = () => {
// 这样写可以导致shallowRef的视图更新
  header.value = {
    name: 'ls'
  }
  console.log(header) 
}

refshallowRef不能写在一起,不然会影响shallowRef 造成视图的更新
因为ref的更新底层调用了triggerRef

const changeName = () => {
// 这样写会导致shallowRef的视图更新
  title.value.name = 'I am coming'
  header.value.name = 'ls'
  console.log(header) 
}

triggerRef

强制更新页面DOM

import { ref, shallowRef, triggerRef } from 'vue'
const changeName = () => {
  header.value.name = 'ls'
  // 这样写也会导致shallowRef的视图更新
  triggerRef(header)
  console.log(header)
}

customRef

customRef 是个工厂函数要求我们返回一个对象 并且实现 get set 适合去做防抖之类的

<template>
  <div>customRef:{{ obj }}</div>
  <button @click="changeObj">customRef按钮</button>
</template>
<script setup lang="ts">
import { customRef } from 'vue'

function MyRef<T>(value: T) {
  let timer: any
  return customRef((track, trigger) => {
    return {
      get() {
        track()
        return value
      },
      set(newVal) {
        clearTimeout(timer)
        timer = setTimeout(() => {
          value = newVal
          timer = null
          trigger()
        }, 1000)
      }
    }
  })
}
const obj = MyRef<string>('zs')
const changeObj = () => {
  obj.value = 'customRef'
  console.log(obj)
}
</script>

isRef

用于判断是否为ref对象

import { ref, isRef, shallowRef } from 'vue'
let num = ref(1)
let header = shallowRef({ name: 'zs' })
let message = '123'
console.log(isRef(num), isRef(message), isRef(header)) // true false true

查看console输出

正常查看,要点开对象,然后点击value,才能看到值
在这里插入图片描述
通过点击在在这里插入图片描述
首选项里可以设置选中启用自定义格式化程序
在这里插入图片描述
然后就可以直接看到值了,不用点击两次来查看了

在这里插入图片描述

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

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

相关文章

企业电子招投标采购系统源码之-java spring cloud

​ 信息数智化招采系统 服务框架&#xff1a;Spring Cloud、Spring Boot2、Mybatis、OAuth2、Security 前端架构&#xff1a;VUE、Uniapp、Layui、Bootstrap、H5、CSS3 涉及技术&#xff1a;Eureka、Config、Zuul、OAuth2、Security、OSS、Turbine、Zipkin、Feign、Monitor、…

JavaSE-13 【API工具类和包装类】

文章目录 JavaSE-13 【API工具类和包装类】第一章 Object类1.1 概述1.2 toString 方法1.3 equals 方法1.4 Objects类 第二章 日期时间类2.1 Date类2.2 DateFormat类2.3 Calendar类 第三章 System类3.1 类介绍3.2 currentTimeMillis方法3.3 arraycopy方法 第四章 包装类4.1 概述…

海思3559:MMZ内存、OS内存配置

前言 海思3559的DDR最大支持到8GB hi3559av100芯片的内存地址范围 (1)通过查阅数据手册可知《Hi3559AV100 专业型 Smart IP Camera SoC 用户指南》&#xff0c;芯片的内存地址范围是0x4000_0000-0x23FFF_FFFF&#xff0c;最大能支持8G内存&#xff1b;   (2)海思芯片把内存分…

Matlab绘制多个曲线的图及局部放大细节展示

绘制多个曲线的图及局部放大细节展示 在科学研究中&#xff0c;经常需要绘制多个曲线并展示局部放大的细节(如下图)。 本篇博客介绍了如何使用MATLAB绘制多个曲线&#xff0c;并在同一张图中添加局部放大图&#xff0c;以展示具体细节。 示例数据 首先&#xff0c;我们准备…

六、2.云尚办公-权限管理

云尚办公系统&#xff1a;前端权限对接&#xff08;了解&#xff09; B站直达【为尚硅谷点赞】: https://www.bilibili.com/video/BV1Ya411S7aT 本博文以课程相关为主发布&#xff0c;并且融入了自己的一些看法以及对学习过程中遇见的问题给出相关的解决方法。一起学习一起进步…

pcl经典算法60例——(1)打开并显示点云

一、搭建MFC框架 1、环境说明 本教程为vs2022&#xff0c;pcl1.12.1版本&#xff0c;其他版本自己进行适当修改&#xff0c;仅供参考。 2、方法步骤 (1)新建项目&#xff0c;选择“基于对话框”&#xff0c;然后点击“下一步” 二、配置pcl环境 关于配置环境&#xff0c;网…

Linux--man指令

语法&#xff1a; man [选项] 命令 功能&#xff1a; 查询命令的详细信息&#xff0c;包括man命令本身 选项&#xff1a; -k 根据关键字搜索联机帮助num 只在第num章节找-a 将所有章节的都显示出来&#xff0c;比如 man printf 它缺省从第一章开始搜索&#xff0c;知道就停止…

spring security登录接口鉴权原理

使用了gatewayspring security,项目当初打算使用gateway统一鉴权的&#xff0c;整合步骤点击此处 当时没有深入security&#xff0c;今天偶然看代码发现验证密码的时候加密了&#xff0c;但是登录表单提交的密码没有加密。看下代码吧 登录接口验证账号密码是否正确 postman登录…

Vue如何生成二维码 qrcode.js2

QRCode.js是一个二维码生成javascript库&#xff1b;支持跨浏览器的HTML5 Canvas和表格标签的DOM操作&#xff1b;并且不依赖其它的库或拓展。 官网地址&#xff1a;https://davidshimjs.github.io/qrcodejs/ 安装方式&#xff1a;&#xff08;qrcode.js有两个版本我用的是第…

软件测试练手项目,可以写进简历里面的项目实战

最近收到许多自学自动化测试的小伙伴私信&#xff0c;学习了理论知识后&#xff0c;却没有合适的练手项目。 测试本身是一个技术岗位&#xff0c;如果只知道理论&#xff0c;没有实战经验&#xff0c;在面试中很难说服面试官&#xff0c;比如什么场景下需要添加显示等待&#x…

LIN诊断实现MCU本地OTA升级

一、目标 通过PC端上位机实现MCU本地的OTA升级,本篇文章对实现的目的、需要用到的第三方工具、LIN诊断帧、升级协议、MCU端升级过程以及PC端升级过程做详细说明。 二、目的 最近在做MCU项目时需要将样机寄给客户进行验证,在客户的验证过程中要求参数可调试,如果需要修改软…

【AUTOSAR】BMS开发实际项目讲解(二十二)----电池管理系统高压绝缘保护

高压绝缘保护 关联的系统需求 TSR-BMS-5101、TSR-BMS-5102、TSR-BMS-5103、TSR-BMS-5104、TSR-BMS-5105、TSR-BMS-5106、TSR-BMS-5107、TSR-BMS-5108、TSR-BMS-5109、TSR-BMS-5110、TSR-BMS-5111、TSR-BMS-5112、TSR-BMS-5113、TSR-BMS-5114、TSR-BMS-5115、TSR-BMS-5116; TSR…

图像平滑处理:cv::filter2D()函数详解

cv::filter2D 函数可以对图像进行线性滤波。 函数可以对图像进行线性滤波。该函数使用指定的卷积核对输入图像进行卷积&#xff0c;以计算输出图像中每个像素的值。 该函数的原型如下&#xff1a; void cv::filter2D(InputArray src, OutputArray dst, int ddepth, InputArr…

JAVA IO流 File 字节流 字符流(tedu)

JAVA IO流 File 字节流 字符流(tedu) 目录 JAVA IO流 File 字节流 字符流(tedu)IO简介1 流Stream2 IO流的继承结构3 File文件类3.1概述3.2创建对象3.3 常用方法 4 字节流读取4.1 InputStream抽象类4.2 FileInputStream子类4.3 BufferedInputStream子类4.4 练习&#xff1a;字节…

Radio Transmission

[BOI2009] Radio Transmission 无线传输 题目描述 给你一个字符串 s 1 s_1 s1​&#xff0c;它是由某个字符串 s 2 s_2 s2​ 不断自我连接形成的&#xff08;保证至少重复 2 2 2 次&#xff09;。但是字符串 s 2 s_2 s2​ 是不确定的&#xff0c;现在只想知道它的最短长度…

亚马逊云科技如何通过四大自研芯片助力企业创新,摆脱基础架构束缚

2023年6月27-28日&#xff0c;2023亚马逊云科技中国峰会在上海顺利举行。在此次峰会上我们可以清晰地看到为什么亚马逊云科技可以做到领先地位&#xff0c;为什么亚马逊云科技可以一直保持进步。这都与亚马逊云科技“基于客户需求&#xff0c;快速进行产品更新与技术迭代”的Da…

ethtool 原理介绍和解决网卡丢包排查思路

前言 之前记录过处理因为 LVS 网卡流量负载过高导致软中断发生丢包的问题&#xff0c;RPS 和 RFS 网卡多队列性能调优实践[1]&#xff0c;对一般人来说压力不大的情况下其实碰见的概率并不高。这次想分享的话题是比较常见服务器网卡丢包现象排查思路&#xff0c;如果你是想了解…

使用Prometheus+Grafana实现监控

使用PrometheusGrafana实现监控 我们用 actuator 暴露应用本身的线程、bean 等信息&#xff0c;但是这些信息还是独立于 Prometheus 之外的。下面我们 将介绍如何将 SpringBoot Actuator 与 Prometheus 结合起来。 我们同样从 Spring Initializr 创建一个名为 spring-web-pr…

从零开始 Spring Boot 54:@NotNull in Entity

从零开始 Spring Boot 54&#xff1a;NotNull in Entity 图源&#xff1a;简书 (jianshu.com) 之前通过两篇文章介绍了 Hibernate Validation 在 Spring 中的应用&#xff1a; 从零开始 Spring Boot 13&#xff1a;参数校验 - 红茶的个人站点 (icexmoon.cn)从零开始 Spring B…