vue3-(reactive全家桶)
1.reactive:用来绑定复杂的数据类型:数组,对象等。
注意:reactive如果绑定的是基础类型数据会报错。
<template> <button @click="onChangeMsg">修改数据</button> <div>{{ obj.name }}</div> </template> <script setup lang="ts"> import { reactive } from 'vue'; let obj = reactive({ name: '张三', age: 18, boj: { namespaced: true } }); setTimeout(() => { obj.name = '异步赋值无效'; }, 2000); const onChangeMsg = () => { obj.name = '李四'; }; </script>
2.readonly:拷贝一份proxy对象并设置为只读属性
<template> <button @click="onChangeMsg">修改数据</button> <div>{{ obj.name }}</div> </template> <script setup lang="ts"> import { reactive, readonly } from 'vue'; let obj = reactive({ name: '张三', age: 18, boj: { namespaced: true } }); let CopyObj = readonly(obj); setTimeout(() => { CopyObj.name = '异步赋值无效'; }, 2000); const onChangeMsg = () => { CopyObj.name = '李四'; }; </script>
3.shallowReactive:拷贝一份对象,可以修改浅层数据,无法修改深层数据
<template> <button @click="onChangeMsg">修改数据</button> <div>{{ obj.name }}</div> </template> <script setup lang="ts"> import { reactive, shallowReactive } from 'vue'; let obj = reactive({ name: '张三', age: 18, boj: { namespaced: true } }); let CopyObj = shallowReactive(obj); setTimeout(() => { //可以修改 CopyObj.name = '异步赋值'; //无法修改 CopyObj.boj.namespaced = false; }, 2000); console.log(CopyObj.boj.namespaced); const onChangeMsg = () => { CopyObj.name = '李四'; }; </script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!