Vue3组合式响应式数据

2024-05-16 05:44

本文主要是介绍Vue3组合式响应式数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ref
基本数据类型

number、boolean、string等等使用的方式都跟下面类似;底层实现响应式也是对象,有兴趣的朋友可以去看源码

<template><div>{{ counter }}</div><button @click="add">+</button><button @click="increment">-</button>
</template>
​
<script setup>
import { ref } from 'vue'
import { ElMessage } from 'element-plus'
const counter = ref(0)
const add = () => {counter.value += 1
}
function increment() {if(counter.value <= 0) {ElMessage({message: 'counter不能小于0',type: 'warning',})return}counter.value -= 1
}
</script>
引用数据类型
<template><div v-for="(item, index) in names" :key="index">{{ item }}</div><button @click="addUser">添加用户</button>
</template>
​
<script setup>
import { ref } from 'vue'
const names = ref(['张三'])
function addUser() {names.value.push('李四')
}
</script>
动态添加、删除属性
<template><div v-for="(item, index) in user" :key="index">{{ item }}</div><div><button @click="addUserInfo" style="padding-right: 6px;">添加用户信息</button><button @click="removeUserInfo">删除用户信息</button></div>
</template>
​
<script setup>
import { ref } from 'vue'
const user = ref({})
function addUserInfo() {user.value = {name: 'alan',age: 18}
}
function removeUserInfo() {delete user.value.age
}
</script>
获取dom、组件实例

父组件

<template><div><div ref="domRef">Hello Vue !!</div><div style="margin-bottom: 20px;"><el-button @click="editDomText">换一个</el-button></div><ChildCom ref="child1" /><el-button @click="getChildContent">获取子组件方法和数据</el-button></div>
</template>
​
<script setup>
import ChildCom from './components/childCom.vue';
const domRef= ref(null)
const child1 = ref(null)
const editDomText = () => {domRef.value.textContent = 'Hello Alan'
}
function getChildContent() {console.log('运行子组件方法');child1.value.childFun()console.log('获取子组件响应式数据', child1.value.user);console.log('获取子组件dom内容');console.log(child1.value.getChildDomData());
}
</script>

子组件

<template><div><div ref="child">这是子组件的ref</div></div>
</template>
​
<script setup>
import {ref} from 'vue'
const child =  ref(null)
const user = ref({username: 'alan',age: 18
})
function childFun() {console.log('这是子组件方法');
}
function getChildDomData() {const text =  child.value.textContentreturn text
}
// 暴露子组件的方法、属性等
defineExpose({childFun,user,getChildDomData
})
</script>

reactive

reactive(attr)只能把Array、Object等了类型作为实参,不能传入基本数据类型

<template><div v-for="(item, index) in data" :key="index">{{ item }}</div><div><button @click="addUserInfo" style="padding-right: 6px;">添加用户信息</button><button @click="removeUserInfo">删除用户信息</button></div>
</template>
​
<script setup>
import { reactive } from 'vue'
const data = reactive([])
const data = reactive({username: 'alan'
})
data.push('张三')
function addUserInfo() {data.push('李四')
}
function removeUserInfo() {delete data[0]
}
</script>

这篇关于Vue3组合式响应式数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient