reactive创建对象类型的响应式数据

ref创建基本类型的响应式数据
  • template里面不需要用.value
  • 但js中使用ref的都要用.value

下面为反例

csharp 复制代码
 //数据
 let name=ref('张三')
   let age=ref(18)
   let tel='123456789'//不用响应式
   //方法
  function changename(){
   name='asd'//这样会报错,需要加.value
  }
  function changeage(){
   age+=1
 }
 function showTel(){
   alert(tel)
 }

举例

xml 复制代码
 <script lang="ts" setup name="person">
 import {ref} from 'vue'
 // let a=666
 //数据
 let name=ref('张三')
   let age=ref(18)
   let tel='123456789'//可不用响应式
   //方法
  function changename(){
   name.value='asd'
  }
  function changeage(){
   age.value+=1
 }
 function showTel(){
   alert(tel)
 }
 </script>
 ​

reactive创建对象类型的响应式数据

reactive是深层次的,ref是浅层次的

reactive局限性:

reactive包裹的对象不可整体修改

xml 复制代码
 <template>
   <div class="person">
 <h2>
  汽车信息: 一辆{{ car.brand }}车,价值{{ car.price }}万
 </h2>
 <button @click="changePrice">修改汽车的价格</button>
 <br>
 <h2>游戏列表</h2>
 <ul>
   <li v-for="g in games" :key="g.id">{{ g.name }}</li>
   <button @click="changename">修改第一个游戏的名字</button>
 </ul>
   </div>
 </template>
 ​
 ​
 ​
 //这个script配置组件API
 <script lang="ts" setup name="person">
 ​
 import {reactive} from 'vue'
 ​
 //数据
 let car=reactive({
   brand:'奔驰',price:100
 })
 let games=reactive([
   {id:'01',name:'aa'},
   {id:'02',name:'bb'},
   {id:'03',name:'cc'}
 ])
   //方法
  function changePrice(){
   car.price+=10
  }
  function changename(){
   games[0].name='kkk'
  }
 </script>
 <style>
 .person{
 background-color: rgb(178, 178, 216);
 box-shadow: 0 0 10px;
 border-radius: 10px;
 padding: 20px;
 ​
 }
 button{
   margin: 0 5px;
 }
 li{
   font-size: 20px;
 }
 </style>

ref可以定义 基本类型、对象类型的响应式数据

reactive只能定义 对象类型的响应式数据

ref和reactive区别:

ref创建的变量必须使用.value

reactive 重新分配一个新对象,会失去响应式

相关推荐
We་ct42 分钟前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
wefly20171 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒2 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro2 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳2 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授2 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
zayzy3 小时前
前端八股总结
开发语言·前端·javascript
今天减肥吗3 小时前
前端面试题
开发语言·前端·javascript
Rabbit_QL3 小时前
【前端UI行话】前端 UI 术语速查表
前端·ui·状态模式
小码哥_常3 小时前
一文带你吃透Android BLE蓝牙开发全流程
前端