vue3语法中ref
、isRef
、toRef
、toRefs
、toRaw
的用法有什么不同,下面编程教程网小编给大家简单介绍一下各种用法!
ref 属性除了能够获取元素外,也可以使用 ref 函数,创建一个响应式数据,当数据值发生改变时,视图自动更新。
<script lang="ts" setup>
import { ref } from 'vue'
let str: string = ref('我是张三')
const chang = () => {
str.value = '我是钻石王老五'
console.log(str.value)
}
</script>
<template>
<div>
{{ str }}
<button type="button" @click="chang">修改值</button>
</div>
</template>
isRef检查变量是否为一个被 ref 包装过的对象,如果是返回 true ,否则返回 false。
import { ref, isRef, reactive } from 'vue'
let str: string = ref('我是张三')
let num: number = 1
let per = reactive({ name: '代码女神', work: '程序媛' })
console.log('strRes', isRef(str)) //true
console.log('numRes', isRef(num)) //false
console.log('perRes', isRef(per)) //false
toRef创建一个 ref 对象,其 value 值指向另一个对象中的某个属性。
toRef(obj, key) 将对象中的某个值转化为响应式数据,分为两种情况:
toRef 定义原始非响应式数据,修改值时,原始数据和 copy 数据都会变的,但是视图不更新。
<script>
import { ref, isRef, toRef, reactive } from 'vue'
let obj = {
name: '姓名',
age: 18,
}
let name: string = toRef(obj, 'name')
const chang = () => {
obj.name = '钻石王老五'
name.value = '李四'
console.log(obj.name) // 李四
console.log('name', name) // 李四
}
//chang() //DOM挂载前调用
</script>
<template>
<div>
{{ obj.name }} ------- {{ name }}
<button type="button" @click="chang">修改值</button>
</div>
</template>
注意:如果是在 DOM 挂载之前调用 chang 方法,改变数值,此时数据和视图都会发生改变。
toRef 定义原始数据响应式数据,修改值时,原始数据,和 copy 数据都会改变,视图也会更新。
<script>
import { ref, isRef, toRef, reactive } from 'vue'
let obj = reactive({
name: '姓名',
age: 18,
})
let name: string = toRef(obj, 'name')
const chang = () => {
obj.name = '钻石王老五'
name.value = '李四'
}
</script>
<template>
<div>
{{ obj.name }} ------- {{ name }}
<button type="button" @click="chang">修改值</button>
</div>
</template>
toRefs 用来解构 ref、reactive 包裹的响应式数据。接收一个对象作为参数,遍历对象上的所有属性,将对象上的所有属性变成响应式数据。
let obj = reactive({
name: '姓名',
age: 18,
})
let { name, age } = toRefs(obj)
const chang = () => {
name.value = '钻石王老五'
age.value++
}
</script>
<template>
<div>
{{ name }} ------- {{ age }}
<button type="button" @click="chang">修改值</button>
</div>
</template>
toRefs 解构数据时,如果某些参数作为可选参数,可选参数不存在时就会报错,如:
let obj = reactive({
name: '姓名',
age: 18,
})
let { name, age, work } = toRefs(obj)
const chang = () => {
name.value = '钻石王老五'
age.value++
console.log('work', work.value)
work.value = '程序媛'
}
此时可以使用 toRef 解决此问题,使用 toRef 解构对象某个属性时,先检查对象上是否存在该属性,如果存在就继承对象上的属性值,如果不存在就会创建一个。
修改上边的代码为:
let obj = reactive({
name: '姓名',
age: 18,
})
let { name, age } = toRefs(obj)
let work = toRef(obj, 'work')
const chang = () => {
name.value = '钻石王老五'
age.value++
console.log('work', work.value)
work.value = '程序媛'
}
toRaw将响应式对象转为原始对象。做一些不想被监听的事情,从 ref 或 reactive 得到原始数据。
修改原响应式数据时,toRaw 转换得到的数据会被修改,视图也会更新,如:
<script lang="ts" setup>
import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
let obj = reactive({
name: '姓名',
age: 18,
})
let newObj = toRaw(obj)
const chang = () => {
obj.name = '钻石王老五'
obj.age++
}
</script>
<template>
<div>
{{ obj.name }} ------- {{ obj.age }}
<button type="button" @click="chang">修改值</button>
<br />
{{ newObj }}
</div>
</template>
如果修改 toRaw 得到的原始数据,原数据也会被修改,但是视图不更新。如:
<script lang="ts" setup>
import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
let obj = reactive({
name: '姓名',
age: 18,
})
let newObj = toRaw(obj)
const chang = () => {
obj.name = '钻石王老五'
obj.age++
}
const changNew = () => {
newObj.name = '搞笑'
console.log('newObj', newObj)
console.log('obj', obj)
}
</script>
<template>
<div>
{{ obj.name }} ------- {{ obj.age }}
<button type="button" @click="chang">修改值</button>
<br />
{{ newObj }}
<button @click="changNew">修改</button>
</div>
</template>
以上是编程学习网小编为您介绍的“vue3语法中关于ref、isRef、toRef、toRefs、toRaw的基本用法”的全面内容,想了解更多关于 vuejs 内容,请继续关注编程基础学习网。
本文标题为:vue3语法中关于ref、isRef、toRef、toRefs、toRaw的基本用法
基础教程推荐
- jQuery层叠选择器用法实例分析 2024-04-08
- vuejs如何console.log打印div中的内容并去除标签 2025-01-17
- jQuery表单域属性过滤器用法分析 2024-04-26
- JavaScript 设计模式中的代理模式详解 2022-08-31
- 基于Cookie常用操作以及属性介绍 2024-03-21
- React Native中NavigatorIOS组件的简单使用详解 2024-01-06
- uni-app调取接口的3种方式以及封装uni.request()详解 2022-10-21
- CSS伪元素 CSS:before CSS伪元素(Pseudo Element):after与:before 2024-01-23
- HTML-Canvas的优越性能以及实际应用 2022-11-20
- window.location.hash 使用说明 2024-02-11