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

相关推荐
我命由我123453 分钟前
微信小程序 - 页面跳转并传递参数(使用路由参数、使用全局变量、使用本地存储、使用路由参数结合本地存储)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
DJ斯特拉6 分钟前
日志技术Logback
java·前端·logback
HIT_Weston11 分钟前
49、【Ubuntu】【Gitlab】拉出内网 Web 服务:http.server 单/多线程分析(一)
前端·ubuntu·gitlab
涔溪13 分钟前
Vue3 中ref和reactive的核心区别是什么?
前端·vue.js·typescript
天意__16 分钟前
Flutter开发,scroll_to_index适配flutter_list_view
前端·flutter
吉星9527ABC19 分钟前
表示离散量的echarts图型示例
前端·arcgis·echarts·离散量web展示
光影少年21 分钟前
web3学习路线
前端·学习·前端框架·web3
克喵的水银蛇21 分钟前
Flutter 状态管理:Provider 入门到实战(替代 setState)
前端·javascript·flutter
鹏多多23 分钟前
flutter-使用url_launcher打开链接/应用/短信/邮件和评分跳转等
android·前端·flutter
刻刻帝的海角24 分钟前
响应式数据可视化 Dashboard
开发语言·前端·javascript