Vue3+ts(day03:ref和reactive)

2024-04-27 13:28

本文主要是介绍Vue3+ts(day03:ref和reactive),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes

觉得有帮助的同学,可以点心心支持一下哈(笔记是根据b站上学习的尚硅谷的前端视频【张天禹老师】,记录一下学习笔记,用于自己复盘,有需要学习的可以去b站学习原版视频)

一、ref 创建(基本类型的响应式数据)

  • 作用:定义响应式变量。
  • 语法:let xxx = ref(初始值)。
  • 返回值:一个RefImpl的实例对象,简称ref对象或ref,ref对象的value属性是响应式的
  • 注意点:
    • JS中操作数据需要:xxx.value,但模板中不需要.value,直接使用即可。
    • 对于let name = ref('张三')来说,name不是响应式的,name.value是响应式的。
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="changeName">修改名字</button><button @click="changeAge">年龄+1</button><button @click="showTel">点我查看联系方式</button></div>
</template><script setup lang="ts" name="Person">import {ref} from 'vue'// name和age是一个RefImpl的实例对象,简称ref对象,它们的value属性是响应式的。let name = ref('张三')let age = ref(18)// tel就是一个普通的字符串,不是响应式的let tel = '13888888888'function changeName(){// JS中操作ref对象时候需要.valuename.value = '李四'console.log(name.value)// 注意:name不是响应式的,name.value是响应式的,所以如下代码并不会引起页面的更新。// name = ref('zhang-san')}function changeAge(){// JS中操作ref对象时候需要.valueage.value += 1 console.log(age.value)}function showTel(){alert(tel)}
</script>

二、reactive 创建(对象类型的响应式数据)

  • 作用:定义一个响应式对象(基本类型不要用它,要用ref,否则报错)
  • 语法:let 响应式对象= reactive(源对象)。
  • 返回值:一个Proxy的实例对象,简称:响应式对象。
  • 注意点:reactive定义的响应式数据是“深层次”的。
<template><div class="person"><h2>汽车信息:一台{{ car.brand }}汽车,价值{{ car.price }}万</h2><h2>游戏列表:</h2><ul><li v-for="g in games" :key="g.id">{{ g.name }}</li></ul><h2>测试:{{ obj.a.b.c.d }}</h2><button @click="changeCarPrice">修改汽车价格</button><button @click="changeFirstGame">修改第一游戏</button><button @click="test">测试</button></div>
</template><script lang="ts" setup name="Person">
import { reactive } from 'vue'// 数据
let car = reactive({ brand: '迈巴赫', price: 200 })
let games = reactive([{ id: 'ahsgdyfa01', name: '英雄联盟' },{ id: 'ahsgdyfa02', name: '王者荣耀' },{ id: 'ahsgdyfa03', name: '原神' }
])
let obj = reactive({a: {b: {c: {d: 666}}}
})function changeCarPrice () {car.price += 10
}
function changeFirstGame () {games[0].name = '流星蝴蝶剑'
}
function test () {obj.a.b.c.d = 999
}
</script>

三、ref 创建(对象类型的响应式数据)

  • 其实ref接收的数据可以是:基本类型对象类型
  • 若ref接收的是对象类型,内部其实也是调用了reactive函数。
<template><div class="person"><h2>汽车信息:一台{{ car.brand }}汽车,价值{{ car.price }}万</h2><h2>游戏列表:</h2><ul><li v-for="g in games" :key="g.id">{{ g.name }}</li></ul><button @click="changeCarPrice">修改汽车价格</button><button @click="changeFirstGame">修改第一游戏</button></div>
</template><script lang="ts" setup name="Person">
import { ref } from 'vue'// 数据
let car = ref({ brand: '迈巴赫', price: 200 })
let games = ref([{ id: 'ahsgdyfa01', name: '英雄联盟' },{ id: 'ahsgdyfa02', name: '王者荣耀' },{ id: 'ahsgdyfa03', name: '原神' }
])function changeCarPrice () {car.value.price += 10
}
function changeFirstGame () {games.value[0].name = '流星蝴蝶剑'
}
</script>

四、ref 对比 reactive

宏观角度看:

  1. ref用来定义:基本类型数据对象类型数据
  2. reactive用来定义:对象类型数据

区别:

  1. ref创建的变量必须使用.value(可以打开设置里面的插件自动添加.value)。
  2. reactive重新分配一个新对象,会失去响应式(可以使用Object.assign去整体替换)。

先安装这个插件,之前老师推荐的插件好像不能用了

然后点击设置,找到扩展,如下图:

在扩展中找到vue,勾选Auto Insert:Dot Value

使用原则:

  1. 若需要一个基本类型的响应式数据,必须使用ref。
  2. 若需要一个响应式对象,层级不深,ref、reactive都可以。
  3. 若需要一个响应式对象,且层级较深,推荐使用reactive。

五、toRefs 与 toRef

  • 作用:将一个响应式对象中的每一个属性,转换为ref对象(适用于解构对象时使用)
  • 备注:toRefs与toRef功能一致,但toRefs可以批量转换。
  • 语法如下:
<template><div class="person"><h2>姓名:{{person.name}}</h2><h2>年龄:{{person.age}}</h2><h2>性别:{{person.gender}}</h2><button @click="changeName">修改名字</button><button @click="changeAge">修改年龄</button><button @click="changeGender">修改性别</button></div>
</template><script lang="ts" setup name="Person">import {ref,reactive,toRefs,toRef} from 'vue'// 数据let person = reactive({name:'张三', age:18, gender:'男'})// 通过toRefs将person对象中的n个属性批量取出,且依然保持响应式的能力let {name,gender} =  toRefs(person)// 通过toRef将person对象中的gender属性取出,且依然保持响应式的能力let age = toRef(person,'age')// 方法function changeName(){name.value += '~'}function changeAge(){age.value += 1}function changeGender(){gender.value = '女'}
</script>

六、computed

作用:根据已有数据计算出新数据(和Vue2中的computed作用一致)。

<template><div class="person">姓:<input type="text" v-model="firstName"> <br>名:<input type="text" v-model="lastName"> <br>全名:<span>{{fullName}}</span> <br><button @click="changeFullName">全名改为:li-si</button></div>
</template><script setup lang="ts" name="App">import {ref,computed} from 'vue'let firstName = ref('zhang')let lastName = ref('san')// 计算属性——只读取,不修改/* let fullName = computed(()=>{return firstName.value + '-' + lastName.value}) */// 计算属性——既读取又修改let fullName = computed({// 读取get(){return firstName.value + '-' + lastName.value},// 修改set(val){console.log('有人修改了fullName',val)firstName.value = val.split('-')[0]lastName.value = val.split('-')[1]}})function changeFullName(){fullName.value = 'li-si'} 
</script>

这篇关于Vue3+ts(day03:ref和reactive)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/940620

相关文章

57.基于SpringBoot + Vue实现的前后端分离-在线教育系统(项目 + 论文PPT)

项目介绍         随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了在线教育系统的开发全过程。通过分析在线教育系统管理的不足,创建了一个计算机管理在线教育系统的方案。文章介绍了在线教育系统的系统分析部分,包括可行性分析等,系统设计部分主要介绍了系统功能设计和数据库设计。         本站是一个B/S模式系统,采用SpringBoot + V

【JavaEE】博客系统(前端页面设计)

文章目录 一、预期效果二、实现博客列表页 一、预期效果 二、实现博客列表页 实现导航栏 编辑 blog_list.html, 创建导航栏的 html 代码. 导航栏里面包含 logo, 标题, 以及一些按钮(跳转链接). 为了实现左右排列, 在 logo 和 按钮 之间加一个 spacer 作为占位器. <!-- 导航栏 --><div class="nav

使用jQuery插件flexigrid搭建项目框架

今天来了,不能懒,该写就写; 1.既然是要用jQuery的JS 。那就要放入项目中 2.使用方式jsp+js: 3.调用后台 $(function() {$("#flexgrid").flexigrid({url : webroot+'sand/messageCodeImportAction!getPagedCityList.action',dataType

医院预约挂号|基于Springboot+vue的医院预约挂号系统小程序的设计与实现(源码+数据库+文档)

医院预约挂号系统小程序 目录 基于Springboot+vue的医院预约挂号系统小程序设计与实现 一、前言 二、系统设计 三、系统功能设计  1小程序端  后台功能模块 4.2.1管理员功能 4.2.2医生功能 四、数据库设计  五、核心代码  六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: 博主介绍:✌️大厂码农|毕设布道师,阿里云开

HTML5+CSS3实现小黄人

HTML代码: <!-- 小黄人的容器 --><div class="wrap"><!-- 小黄人的头发 --><div class="xhr_hair"><div class="xhr_hair_1"></div><div class="xhr_hair_2"></div></div><!-- 小黄人的身体 --><div class="xhr_body"><!-- 小黄人的眼镜 --><d

CSS滑动门效果

类似日常生活中的滑动门,根据a链接不同的文字宽度,自动撑开相应的背景宽度。 HTML代码如下: <div><ul><li><a href="#"><span>首页</span></a></li><li><a href="#"><span>开放平台</span></a></li><li><a href="#"><span>表情开放平台</span></a></li><li><a href="#">

Vue中自动生成路由配置文件覆盖路由配置

Vue中自动生成路由配置文件覆盖路由配置 设计思路 读取@/views下所有index.vue如果当前文件下有包含相同路径则认为是它的子路由。但也不能就这样写死,要创建page.(ts|js)配置文件也可以更改当前的配置,Page.(ts|js)比重大于自动生成的路由配置。 踩坑点 坑点1 这里的'@/views'不能使用变量传入。 (require as any).context('

vue3+ts+vant选择器选中文字效果

所需要的样式: 选中某个选项后文字有放大和改变颜色的效果 主要就是在van-picker上加class, 给对应的style样式即可 <van-pickerclass="custom-picker":title="pickerData.titleText"v-if="pickerData.ispicker"show-toolbar:columns="columns"@confirm="onCo

接上一篇:webpack中html-webpack-plugin的使用及配置生成html

1. 安装html-webpack-plugin: cnpm i html-webpack-plugin@2.24.1 -D 2. webpack.dev.config.js中配置: var path = require('path');// 引入html-webpack-pluginconst HtmlWebpackPlugin = require('html-webpack-plug

webpack中css-loader、style-loader的使用

项目目录结构如下: 各文件源码如下: index.html: <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title></head>