vue3-(toRef,toRefs,toRaw)

1.toRef:从响应式对象上,创建一个新的ref对象

复制代码
<template>
  <button @click="onChangeMsg">修改数据</button>
  <div>{{ obj.name }}</div>
</template>

<script setup lang="ts">
import { reactive, toRef } from 'vue';
let obj = reactive({
  name: '张三',
  age: 18,
  boj: {
    namespaced: true
  }
});
let name = toRef(obj, 'name');
setTimeout(() => {
  //可以修改
  name.value = '异步赋值';
}, 2000);
console.log('name', name);
const onChangeMsg = () => {
  name.value = '李四';
};
</script>
复制代码

2.toRefs:可以帮我们批量创建ref对象主要是方便我们解构使用

复制代码
<template>
  <button @click="onChangeMsg">修改数据</button>
  <div>{{ obj.name }}</div>
</template>

<script setup lang="ts">
import { reactive, toRefs } from 'vue';
let obj = reactive({
  name: '张三',
  age: 18,
  boj: {
    namespaced: true
  }
});
let { name, age, boj } = toRefs(obj);
setTimeout(() => {
  //可以修改
  name.value = '异步赋值';
}, 2000);
console.log('name', name);
console.log('age', age);
console.log('boj', boj);
const onChangeMsg = () => {
  name.value = '李四';
};
</script>
复制代码

3.toRaw:将响应式对象修改为普通对象

复制代码
<template>
  <button @click="onChangeMsg">修改数据</button>
  <div>{{ obj.name }}</div>
  <div>{{ toObj }}</div>
</template>

<script setup lang="ts">
import { reactive, toRaw } from 'vue';
let obj = reactive({
  name: '张三',
  age: 18,
  boj: {
    namespaced: true
  }
});
let toObj = toRaw(obj);
setTimeout(() => {
  //可以修改
  toObj.name = '异步赋值';
}, 2000);
const onChangeMsg = () => {
  toObj.name = '李四';
};
console.log('toObj', toObj);
</script>
复制代码

 

posted @   银河游鱼  阅读(488)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示