使用ref定义响应式数据变量

Ref

使用 Ref 可以方便地创建和管理Vue组件中的响应式数据。例如,如果你有一个计数器组件,你可以使用 Ref 来创建一个响应式的计数器变量,然后在组件内部或外部修改这个变量的值,而不需要手动触发视图更新。

先声明一个变量,然后用插值表达式在template中渲染出来,代码如下:

<template><view>{{num1}}</view></template><script setup>let num1 = 6 ;
</script><style></style>

效果如下:
在这里插入图片描述
接着,尝试定义一个计时器,让数字每秒钟增加1,并输出出来,代码如下:

<template><view>{{num1}}</view></template><script setup>let num1 = 6 ;setInterval(()=>{num1 ++ ;console.log(num1) ;},1000)
</script><style></style>

效果如下:

在这里插入图片描述
可以看到,页面的数字是没有发生变化的,但控制台里正常在计数。这样,说明定义的变量,并不是响应式的,该如何定义一个响应式的变量?

首先,必须从vue模块中,把ref引用过来,然后再重新定义变量,代码如下:

<template><view>{{num1}}</view><view>{{num2}}</view>
</template><script setup>import {ref} from "vue" ;let num1 = 6 ;let num2 = ref(10) ;setInterval(()=>{num2.value ++ ;console.log(num2.value) ;},1000)
</script><style></style>

效果如下:

在这里插入图片描述
成功,所以想要实现响应式变量要注意以下三点:

  1. 从vue中导入ref函数
  2. 定义变量时放在ref里面
  3. 想要获取的值,要加上.value

还可以把字符串、数组、对象放在ref中,在template中渲染出来,代码如下:

<template><view>{{num1}}</view><view>{{num2}}</view><view>{{test}}</view><view>{{arr[2]}}</view><view>{{arr}}</view><view>{{obj}}</view><view>{{obj.name}}</view>
</template><script setup>import {ref} from "vue" ;let num1 = 6 ;let num2 = ref(10) ;let test = ref("字符串")let arr = ref([1,3,5])let obj = ref({name:"张三", age: 18})setInterval(()=>{num2.value ++ ;console.log(num2.value) ;},1000)
</script><style></style>

效果如下:
在这里插入图片描述
修改对象中的name,也要带上.value,代码如下:

<template><view>{{num1}}</view><view>{{num2}}</view><view>{{test}}</view><view>{{arr[2]}}</view><view>{{arr}}</view><view>{{obj}}</view><view>{{obj.name}}</view>
</template><script setup>import {ref} from "vue" ;let num1 = 6 ;let num2 = ref(10) ;let test = ref("字符串")let arr = ref([1,3,5])let obj = ref({name:"张三", age: 18})obj.value.name = "改名成功!"setInterval(()=>{num2.value ++ ;console.log(num2.value) ;},1000)
</script><style></style>

效果如下:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/39769.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Adobe Photoshop 2024 v25.5.1 中文激活版下载以及安装方法教程

软件介绍 Adobe Photoshop 2024 v25.5.1 是Adobe公司的最新版图像处理软件&#xff0c;它提供了强大的图像编辑工具和智能自动化功能&#xff0c;包括图像修复、色彩校正和滤镜效果&#xff0c;以满足专业人士和业余爱好者的需求。这款软件还支持矢量图形设计和实时协作&#…

JavaScript之深入对象,详细讲讲构造函数与常见内置构造函数

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;我是前端菜鸟的自我修养&#xff01;今天给大家详细讲讲构造函数与常见内置构造函数&#xff0c;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;原创不易&#xff0c;如果能帮助到带大家&#xff0c;欢迎…

提升效率:快速绘制线框图的技巧

1、什么是线框 线框作为项目开始时的蓝图或示意图&#xff0c;可以帮助我们更清晰地向相关客户呈现相应的程序或网站的框架结构。从更深层次上讲&#xff0c;线框图代表了产品的基本设计布局&#xff0c;承载着界面显示的关键信息&#xff0c;绘制着要开发的应用程序或网站界面…

【NPU成为边缘智能新思路】

在人工智能&#xff08;AI&#xff09;技术日新月异的今天&#xff0c;从云端到边缘的计算需求不断攀升&#xff0c;为各行各业带来了前所未有的变革机遇。作为这一领域的领军者&#xff0c;Arm 公司凭借其卓越的节能技术和从云到边缘的广泛布局&#xff0c;正逐步构建着未来AI…

LeetCode题练习与总结:二叉树的后序遍历--145

一、题目描述 给你一棵二叉树的根节点 root &#xff0c;返回其节点值的 后序遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[3,2,1]示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[]示例 3&#xff1a; 输入&#xff1a…

AVR晶体管测试仪开源制作与验证

AVR晶体管测试仪开源制作与验证 &#x1f4cd;原项目地址&#xff1a;https://www.mikrocontroller.net/articles/AVR_Transistortester github地址&#xff1a;https://github.com/Mikrocontroller-net/transistortester &#x1f388;EasyEDA项目地址&#xff1a;https://osh…

《数据结构与算法基础 by王卓老师》学习笔记——2.4线性表的顺序表示和实现3

1.线性表的顺序存储表示 2.顺序表示意图 定义变量的时候才会分配空间&#xff0c;光有类型是不分配空间的 3.顺序表的基本操作 增删查三种较难&#xff0c;后面会讲 4.预定义常量和类型 5.算法一&#xff1a;线性表的初始化 6.线性表的几个简单操作 7.算法二&#xff1a;顺序…

鸿蒙自定义dialog弹窗及传参操作

第一步定义一个dialog&#xff1a; CustomDialog export struct InputDialog {controller: CustomDialogController;State counter: string "10";changeInputValue: Function (value: string) > {}build() {Column() {TextArea({ text: this.counter, placehol…

快速上手文心一言指令:解锁AI对话新纪元

快速上手文心一言指令 一、引言&#xff1a;文心一言的魅力所在二、准备工作&#xff1a;了解文心一言平台2.1 轻松注册&#xff0c;开启智能对话之旅2.2 深度探索&#xff0c;掌握界面布局奥秘2.2.1 输入框&#xff1a;智慧交流的起点2.2.2 回复区&#xff1a;即时反馈的窗口2…

IT行业入门,如何假期逆袭,实现抢跑

目录 前言 1.IT行业领域分类 2.基础课程预习指南 3.技术学习路线 4.学习资源推荐 结束语 前言 IT&#xff08;信息技术&#xff09;行业是一个非常广泛和多样化的领域&#xff0c;它包括了许多不同的专业领域和职业路径。如果要进军IT行业&#xff0c;我们应该要明确自己…

从一次 SQL 查询的全过程了解 DolphinDB 线程模型

1. 前言 DolphinDB 的线程模型较为复杂&#xff0c;写入与查询分布式表都可能需要多个类型的线程。通过了解 SQL 查询的全过程&#xff0c;可以帮助我们了解 DolphinDB 的线程模型&#xff0c;掌握 DolpinDB 的配置&#xff0c;以及优化系统性能的方法。 本教程以一个分布式 …

使用hadoop进行数据分析

Hadoop是一个开源框架&#xff0c;它允许分布式处理大数据集群上的大量数据。Hadoop由两个主要部分组成&#xff1a;HDFS&#xff08;Hadoop分布式文件系统&#xff09;和MapReduce。以下是使用Hadoop进行数据分析的基本步骤&#xff1a; 数据准备&#xff1a; 将数据存储在HDF…

【鸿蒙学习笔记】基础组件 Button

官方文档&#xff1a;按钮 (Button)添加链接描述 官方文档&#xff1a;button开发指导 目录标题 属性迭代完善不含子组件的按钮包含子组件的按钮ButtonType添加事件跳转超链接提交表单悬浮按钮 属性迭代完善 不含子组件的按钮 Column({ space: 10 }) {Row() {Button(添加子目…

解决 Enter passphrase for key ‘/Users/xxx/.ssh/id_rsa‘: 问题

问题 在 git 配置 ssh 后&#xff0c;发现每次都需要输入密码&#xff1a; Enter passphrase for key ‘/Users/xxx/.ssh/id_rsa’: 原因 在创建 SSH 公私钥 的时候&#xff0c;输入了密码&#xff0c;现在每次都需要效验之前输入的密码&#xff0c;想要永久的解决这种问题&…

【原理】随机森林模型是怎么训练的

本文来自《老饼讲解-BP神经网络》https://www.bbbdata.com/ 目录 一、随机森林简介二、随机森林训练原理2.1. 随机森林的训练流程2.2. 随机森林训练的核心代码 用过随机森林的朋友都知道&#xff0c;随机森林是集成决策的一个经典代表&#xff0c;它通过训练多棵决策树&#xf…

Zigbee智能家居数据中心:微信小程序实时掌控家居传感器信息

摘要&#xff1a; 本文将介绍如何构建一个基于Zigbee和微信小程序的智能家居网关&#xff0c;实现对家居传感器数据的采集、汇总和展示。用户可通过微信小程序实时查看家中温湿度、光照等环境数据&#xff0c;为智能家居系统提供数据支撑。 关键词&#xff1a; Zigbee&#xf…

是什么让以太坊从众多公链中脱颖而出

以太坊从众多公链中脱颖而出&#xff0c;成为区块链和加密货币领域的一个重要玩家&#xff0c;主要是由于以下几个关键因素&#xff1a; 智能合约&#xff1a; 以太坊是第一个广泛实施智能合约的区块链平台&#xff0c;智能合约允许在区块链上自动执行合同条款&#xff0c;无需…

普利姆最小生成树算法 c++

普里姆(Prim)算法是一种用于在加权连通无向图中查找最小生成树(MST, Minimum Spanning Tree)的贪心算法。最小生成树是一个子图,它包括图中的所有顶点,并且边的总权重最小。该算法的基本思想是从一个顶点开始,逐步扩展生成树,直到包括所有顶点。 算法步骤 初始化: 从…

java内存管理机制(二)-内存分配

在上一篇文章中&#xff0c;我们花了较大的篇幅去介绍了JVM的运行时数据区&#xff0c;并且重点介绍了栈区的结构及作用&#xff0c;在本文中&#xff0c;我们将主要介绍对象的创建过程及在堆中的分配方式。 对象的创建 在上文我们提过一些问题&#xff0c;你的对象是怎么new…

Pump.fun

Pump.fun 是一个专为 Meme 币设计的发布token的工具和社群平台&#xff0c;于2024年1月在Solana区块链上推出&#xff0c;随后扩展至以太坊Layer 2 Blast。它的核心价值在于简化了发币过程&#xff0c;降低了技术门槛&#xff0c;允许任何人以极低的成本&#xff08;0.02SOL&am…