vue3前端开发,自学一下reactive,ref的差异是什么。

vue3前端开发,自学,学习一下,reactive和ref的差别。以及基础用法。

前言,这2个东西,都能对外输出动态的数据对象。但是,有点区别,是,reactive只支持输入一个对象作为参数,ref则还可以支持简单的数据信息作为参数。待会有案例代码展示。

下面看看代码内容。第一个先看看reactive的练习代码。

复制代码
<template>

  <h3>入口文件</h3>
  <!-- <Base /> -->
  <!-- <SetupDemo /> -->
  <ReactiveDemo />

</template>

<script setup>
import Base from './components/Base.vue'
import SetupDemo from './components/SetupDemo.vue'
import ReactiveDemo from './components/ReactiveDemo.vue';
</script>

这个是入口文件,里面调用了一个自定义组件,ReactiveDemo.vue.


复制代码
<script setup>
//reactive基础练习步骤
//1:导入
import { reactive } from 'vue';
//2:调用 -只能支持传入一个传统的对象,作为reactive的参数。
const count = reactive({
    price:10
})
</script>

<template>
    <h3>reactive基础学习</h3>
    <p>草莓单价:{{ count.price }}</p>
</template>

这个ReactiveDemo.vue里面的代码内容。

如图,可以正常获取到,经过reactive包装后的动态对象的内容。因为它是一个对象,所以我们需要使用"."[点]的形式,把里面的数据调用出来。


下面展示的是ref,接收对象形式的参数内容。案例代码。


复制代码
<script setup>
//reactive基础练习步骤
//1:导入
// import { reactive } from 'vue';
//2:调用 -只能支持传入一个传统的对象,作为reactive的参数。
// const count = reactive({
//     price:10
// })

/**
 * ref ,既可以支持对象作参数,又支持简单的数据内容作参数
 */
//1:导入
import { ref } from 'vue';
//2:调用
const count = ref({
    price:99
})
</script>

<template>
    <h3>reactive基础学习</h3>
    <p>草莓单价:{{ count.price }}</p>
</template>

如图,是可以正常获取到草莓的单价为99元。

这个效果,可以使用reactice一样的。

下面展示一下,ref接收一个简单的数据类型的案例效果。以及,如果你想在脚本区域内修改它的数据,需要借助于(*.value)才能修改。


复制代码
<script setup>
//reactive基础练习步骤
//1:导入
// import { reactive } from 'vue';
//2:调用 -只能支持传入一个传统的对象,作为reactive的参数。
// const count = reactive({
//     price:10
// })

/**
 * ref ,既可以支持对象作参数,又支持简单的数据内容作参数
 */
//1:导入
import { ref } from 'vue'
//2:调用
// const count = ref({
//     price:99
// })
//3:ref接收 简单的数据类型。
const count = ref(66)

</script>

<template>
    <h3>reactive基础学习</h3>
    <p>草莓单价:{{ count }}</p>
</template>

这个代码显示的是,我们仅仅是调用了。并未去修改它。所以,直接使用count就能调取成功了。

如图,草莓单价是66元。正常显示了。

如果想更改这个单价,就得借助于,.value了。


复制代码
<script setup>
//reactive基础练习步骤
//1:导入
// import { reactive } from 'vue';
//2:调用 -只能支持传入一个传统的对象,作为reactive的参数。
// const count = reactive({
//     price:10
// })

/**
 * ref ,既可以支持对象作参数,又支持简单的数据内容作参数
 */
//1:导入
import { ref } from 'vue'
//2:调用
// const count = ref({
//     price:99
// })
//3:ref接收 简单的数据类型。
const count = ref(66)
const btnHandle = ()=>{
    count.value++
}
</script>

<template>
    <h3>reactive基础学习</h3>
    <p>草莓单价:{{ count }}</p>
    <button @click="btnHandle">单价+1</button>
</template>

如图,价格确实可以靠点击增加了。

相关推荐
renke33642 分钟前
写给前端的 CANN-torchtitan-npu:昇腾PyTorch Titan适配到底是啥?
前端·人工智能·pytorch·cann
lihaozecq4 分钟前
Agent 开发的 skills 机制设计 - 渐进式披露
前端·agent·ai编程
安妮的小熊呢7 分钟前
CRMEB标准版v6.0: 商城DIY装修新升级,PS级自由设计!
运维·javascript·平面·信息可视化·小程序·开源软件
安生生申8 分钟前
uni-app 连接 JDY-31 蓝牙串口模块实践
c语言·前端·javascript·stm32·单片机·嵌入式硬件·uni-app
Restart-AHTCM12 分钟前
LangChain学习之模型 I/O 与输出解析器 (Output Parsers)(3/8)
前端·学习·langchain
Liu.77412 分钟前
Vue3结合Element Plus封装点击查看大图的自定义指令
javascript·vue.js·elementui
lqj_本人13 分钟前
鸿蒙PC:electron-markdownify 从普通 Electron 迁移到 OpenHarmony Electron HAP 的完整实践
前端·javascript·electron
代码搬运媛8 小时前
Jest 测试框架详解与实现指南
前端
counterxing9 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq9 小时前
windows下nginx的安装
linux·服务器·前端