当前位置: 首页 > news >正文

一篇搞懂vue3中如何使用ref、reactive实现响应式数据

ref 可实现 基本类型、对象类型响应式数据

reactive:只能实现 对象类型响应式

ref实现 基本类型 数据响应式: 

<template>
  <div class="person">
    <h2>姓名:{{ name }}</h2>
    <h2>年龄:{{ age }}</h2>
    <button @click="changeName">修改名字</button>
    <button @click="changeAge">修改年龄</button>
    <button @click="showTel">查看联系方式</button>
  </div>
</template>


<script lang="ts" setup name="person234">
import { ref } from 'vue' //想让哪个数据是响应式的,就用ref包裹

    // 定义数据
    //ref()是一个函数,用来包裹数据,让数据变成响应式的
      let name = ref('张三')
      let age = ref(25)
      let tel = '123-456-7890'
      
      console.log(name)
      
    // 定义方法
      function changeName() {
        name.value = '李四'

        console.log(name)
      }
      function changeAge() {
        age.value = 30        //使用 .value 才能改变ref包裹的数据(包裹之后就变成对象了)
      }
      function showTel() {
        alert(tel)
        console.log(tel)
      }
</script>

<style scoped>
.person {
    background-color: rgb(25, 120, 109);
    box-shadow: 0 0 10px;
    border-radius: 10px;
    padding: 20px;
  }
button {
  margin: 10px;
}
</style>

ref() 包裹之后,name就变成了一个对象 ,修改数据要通过 .value

 ref处理 对象数据 响应式:

<template>
  <div class="person">
    <h2>一辆{{ car.brand }}车,价值{{ car.price }}w</h2>
    <button @click="changePrice">修改汽车价格</button>
    <hr>
    <h2>喜欢的游戏:</h2>
    <ul>
      <li v-for="g in games" :key="g.id">{{ g.name }}</li>
    </ul>
    <button @click="changeFirstgame">修改第一个游戏</button>
  </div>
</template>

<script lang="ts" setup name="Person">
import { ref } from 'vue'
    
  let car = ref({ brand: '奔驰', price: 100 })

  let games = ref([
        {id: 1, name: '王者荣耀'},
        {id: 2, name: '英雄联盟'},
        {id: 3, name: '绝地求生'}
  ])
 
  // 定义方法
  function changePrice() {
    car.value.price += 10     //ref响应式只有.value才能变成响应式
    console.log(car)
  }

function changeFirstgame() {  //ref响应式只有.value才能变成响应式
    games.value[0].name = '植物大战僵尸'
  }

</script>

<style scoped>
.person {
    background-color: rgb(25, 120, 109);
    box-shadow: 0 0 10px;
    border-radius: 10px;
    padding: 20px;
  }
button {
  margin: 10px;
}
li {
  font-size: 20px;
}
</style>

reactive实现对象类型响应式数据:

<template>
  <div class="person">
    <h2>一辆{{ car.brand }}车,价值{{ car.price }}w</h2>
    <button @click="changePrice">修改汽车价格</button>
    <hr>
    <h2>喜欢的游戏:</h2>
    <ul>
      <li v-for="g in games" :key="g.id">{{ g.name }}</li>
    </ul>
    <button @click="changeFirstgame">修改第一个游戏</button>
    <hr>
    <button @click="changeC">修改c的值:{{ obj.a.b.c }}</button>
  </div>
</template>

<script lang="ts" setup name="Person">
  import { reactive } from 'vue'
    // 定义数据
    //reactive()是一个函数,用来包裹对象数据,让其变成响应式的
  let car1 = {brand: '宝马', price: 200 }
  let car = reactive({ brand: '奔驰', price: 100 })
  console.log(car1)
  console.log(car)

  let games = reactive([
        {id: 1, name: '王者荣耀'},
        {id: 2, name: '英雄联盟'},
        {id: 3, name: '绝地求生'}
  ])
  //不管c的值有多深的嵌套,只要是reactive包裹的,都是响应式的
  let obj = reactive({
  a: {
    b: {
      c: 10
    }
  }
  })
    // 定义方法
  function changePrice() {
    car.price += 10
  }

  function changeFirstgame() {
    games[0].name = '植物大战僵尸'
  }
  function changeC() {
    obj.a.b.c = 100
  }
</script>

<style scoped>
.person {
    background-color: rgb(25, 120, 109);
    box-shadow: 0 0 10px;
    border-radius: 10px;
    padding: 20px;
  }
button {
  margin: 10px;
}
li {
  font-size: 20px;
}
</style>

 ​​​

 

ref 和 reactive之间的区别:

 ref 用于定义基本类型数据、对象类型数据。

ref 创建的变量必须使用 .value (可以使用VueOfficial插件 启用dot value来优化)

reactive 用来定义:对象类型数据。

reactive重新分配一个新对象,会失去响应式(可以使用car.value、Object.assign去整体替换)。

<script lang="ts" setup name="Person">
import { ref } from 'vue'

let car = ref({ brand: '奔驰', price: 100 })
let sum = ref(0)

// 定义方法
function changePrice() {
  car.value.price += 10
}
function changeBrand() {
  car.value.brand = '宝马'
}
function changeCar() {
  // 这样写不行,因为car是一个ref对象,不能直接赋值
  // car = { brand: '保时捷', price: 1000 } 

  // 直接替换对象
  // car.value = { brand: '保时捷', price: 1000 } 

  // 合并对象属性
  Object.assign(car.value, { brand: '保时捷', price: 1000 }) 
}

function changeSum() {
  sum.value += 1
}
</script>
  • 使用原则:

  1. 若需要一个基本类型的响应式数据,必须使用ref

  2. 若需要一个响应式对象,层级不深,refreactive都可以。

  3. 若需要一个响应式对象,且层级较深,推荐使用reactive

http://www.dtcms.com/a/31177.html

相关文章:

  • Vue3+element UI:使用el-dialog时,对话框不出现解决方案
  • Mysql 迁移 dm 数据库
  • ip属地是电话号码吗怎么改
  • 企业知识管理平台重构数字时代知识体系与智能服务网络
  • 利用爬虫精准获取淘宝商品描述:实战案例指南
  • 腾讯云cloudstudio使用笔记(一)
  • ros通信与回调函数多线程应用
  • 基于Python+Vue开发的反诈视频宣传管理系统源代码
  • 一文详解U盘启动Legacy/UEFI方式以及GPT/MBR关系
  • MySQL八股学习笔记
  • 回不去的乌托邦
  • 网络通信 之综合布线(Integrated Cabling for Network Communication)
  • MATLAB在投资组合优化中的应用:从基础理论到实践
  • 新品!杰和科技国产化云终端VT32,实现办公“双安全”保障
  • 软件架构设计:架构风格
  • 基于Spring Boot的协同过滤电影推荐系统设计与实现(LW+源码+讲解)
  • C++STL容器之list
  • 基于Spring Boot的农产品智慧物流系统设计与实现(LW+源码+讲解)
  • 06.Docker 镜像制作和管理
  • 智能合约的部署
  • Ubuntu 下 nginx-1.24.0 源码分析 - ngx_os_init 函数
  • 基于SpringBoot的智慧校园管理系统设计与实现的设计与实现(源码+SQL脚本+LW+部署讲解等)
  • Spring BOOT 启动参数
  • UE5.3 C++ TArray系列(一)
  • 深蕾科技智能多媒体SoC产品助力“DataEye剧查查之夜”微短剧盛会
  • Linux自启动fastapi服务
  • Docker 性能优化指南
  • HashMap 详解
  • 学习路之微服务--PHP中实现微服务几种方式
  • LangChain:AI大模型开发与分布式系统设计