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 重新分配一个新对象,会失去响应式

相关推荐
萌萌哒草头将军30 分钟前
⚡⚡⚡尤雨溪宣布开发 Vite Devtools,这两个很哇塞 🚀 Vite 的插件,你一定要知道!
前端·vue.js·vite
小彭努力中1 小时前
7.Three.js 中 CubeCamera详解与实战示例
开发语言·前端·javascript·vue.js·ecmascript
浪裡遊2 小时前
跨域问题(Cross-Origin Problem)
linux·前端·vue.js·后端·https·sprint
LinDaiuuj2 小时前
判断符号??,?. ,! ,!! ,|| ,&&,?: 意思以及举例
开发语言·前端·javascript
敲厉害的燕宝2 小时前
Pinia——Vue的Store状态管理库
前端·javascript·vue.js
Aphasia3112 小时前
react必备JavaScript知识点(二)——类
前端·javascript
玖玖passion2 小时前
数组转树:数据结构中的经典问题
前端
呼Lu噜2 小时前
WPF-遵循MVVM框架创建图表的显示【保姆级】
前端·后端·wpf
珠峰下的沙砾2 小时前
Vue3 里 CSS 深度作用选择器 :global
前端·javascript·css
航Hang*2 小时前
WEBSTORM前端 —— 第2章:CSS —— 第3节:背景属性与显示模式
前端·css·css3·html5·webstorm