网站首页 > 博客文章 正文
我们使用Vue3的setup,触发数据改变,但是数据不会及时更新到页面上,代码如下:
<h2>{{ title }}</h2>
<h2>{{ num }}</h2>
<ul>
<li v-for="(category, index) in categorys" :key="index">
{{ category }}
</li>
</ul>
<button @click="hello">hello</button>
export default {
name: 'App',
setup(){
let title = '商品分类';
let num = 30;
let categorys = ['女装', '男装', '家电'];
return {
title,
num,
categorys,
hello () {
num += 1;
categorys.push('数码');
}
}
}
}
在Vue2定义的数据默认响应式,更改过数据后页面自动更新。但在Vue3的setup做响应式需要额外用上ref,代码如下:
import {ref} from 'vue';
export default {
name: 'App',
setup(){
let title = ref('商品分类');
let num = ref(30);
let categorys = ref(['女装', '男装', '家电']);
return {
title,
num,
categorys,
hello () {
num.value += 1;
categorys.value.push('数码');
}
}
}
}
被ref包裹之后会返回RefImpl对象,使用时必须用.value
// 复杂对象包裹
let prodcut = ref({
title: '电视机',
sku: [{
count: 2,
title: '红色'
}]
});
// 修改数据
let hello = () => {
prodcut.value.sku[0].title = '蓝色';
}
return {
prodcut,
hello
}
猜你喜欢
- 2024-10-04 Vue3的使用toRef和toRefs(vue torefs)
- 2024-10-04 Vue3教程 5.响应式toRef和toRefs函数
- 2024-10-04 vue3的readonly、shallowReadonly、shallowReactive、shallowRef
- 2024-10-04 全网首发:Vue3.5 源码 useTemplateRef #vue
- 2024-10-04 一起学习vue3Ts-ref全家桶(vue3.0全家桶最全入门指南)
- 2024-10-04 Vue语法之ref reactive对比及使用场景
- 2024-10-04 吃瓜!前端人因 Vue3 的 Ref 语法糖提案打起来了
- 2024-10-04 终于搞懂了!原来vue3中template使用ref无需.value是因为这个
- 2024-10-04 vue通过ref实现子父通信(vue父子组件如何通信)
- 2024-10-04 [Vue 3] 为什么需要同时使用Ref和Reactive
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- ifneq (61)
- 字符串长度在线 (61)
- googlecloud (64)
- messagesource (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)