常用知识碎片 Vue3 ref和reactive (内含其他常用知识)

news2024/9/8 12:54:39

目录

ref和reactive

ref

reactive

总结:

setup语法糖

语法糖是啥?

Vue3 setup语法糖

Vue3 不使用setup语法糖示例:

Vue3 使用setup语法糖示例:

ref和eative主要区别


ref和reactive

在 Vue 3 中,ref 和 reactive 是用于创建响应式数据的不同方法,它们主要用于不同的场景:

ref

  • 主要用于创建基本类型的响应式引用,例如字符串、数字或布尔值。
  • ref 返回的是一个具有 .value 属性的对象,实际使用的通常是这个 .value。
  • 当你想要在模板中直接绑定或在计算属性中使用时,ref 非常有用。

 创建响应式对象:

  ref 方法创建一个响应式对象,它会跟踪对象的属性变化,并在这些变化发生时触发视图更新。要使用 ref 方法,您需要将一个对象作为参数传递给它,然后它将返回一个响应式对象。

示例:

import { ref } from 'vue';

const count = ref(0);

count.value++; // 触发视图更新

reactive

  • 用于创建复杂对象或数组的响应式引用,它不会包裹返回值,而是直接返回原始对象或数组。
  • 当你有一个复杂的对象结构并且希望整个对象都是响应式的时,使用 reactive 更加合适。

        创建响应式对象和代理对象:

  reactive 方法创建一个响应式对象和一个代理对象代理对象会跟踪对象的属性变化,并在这些变化发生时触发视图更新。要使用 reactive 方法,您需要将一个对象作为参数传递给它,然后它将返回一个响应式对象和一个代理对象。

示例:

import { reactive } from 'vue';

const state = reactive({
  count: 0,
});

state.count++; // 触发视图更新

小总结:

  • ref 创建一个响应式对象,它会跟踪对象的属性变化,并在这些变化发生时触发视图更新。
  • reactive 创建一个响应式对象和一个代理对象,代理对象会跟踪对象的属性变化,并在这些变化发生时触发视图更新。

以上示例代码都是 Vue3 中不使用语法糖 <script setup>的用法

setup语法糖

语法糖是啥?

        语法糖(Syntactic Sugar) 是编程语言中的一种设计概念,指的是那些为了提高代码的可读性和编写效率而引入的语法特性。这些特性并不会增加语言的基本功能,而是通过提供更加直观或简洁的语法来表达已有的概念,使得代码更加清晰和易于理解。
语法糖的例子包括但不限于:

  • 对象字面量:在JavaScript中,可以直接使用 { key: value } 的形式创建对象,而不是必须调用构造函数 new Object() 并使用 this.key = value 的方式。
  • 自动拆箱和装箱:在Java中,可以将基本类型如 int 和引用类型如 Integer 相互转换,而不需要显式地进行转换操作。
  • 范围for循环:许多语言中,如C#和Java,支持的 foreach 循环,它简化了数组或集合的遍历,而不需要手动管理索引。
  • 模式匹配:在一些函数式语言中,如Haskell或Scala,模式匹配允许你以更直观的方式处理数据结构,而无需显式的条件语句。

        语法糖的主要目的是使代码更加人性化,减少冗余,同时保持代码的逻辑和功能不变。这有助于减少编码错误,并使代码对其他开发者更加友好。然而,过度使用语法糖也可能导致代码变得难以理解和维护,尤其是当其使用方式不常见或非直观时。因此,合理使用语法糖是编程实践中的一项重要技能。

Vue3 setup语法糖

在 Vue 3 中,setup() 函数是组合 API 的核心部分,用于定义组件的响应式状态和逻辑。setup() 是在组件实例被创建后立即执行的,它接收两个参数:props 和 context。但在实际使用中,我们通常只关心 props,因为它包含了父组件传递过来的属性。
setup() 的基本用法
在 setup() 内部,你可以使用来自 Vue 的 Composition API 的各种函数,如 ref, reactive, computed, watch 等,来定义组件的状态和行为。

Vue3 不使用setup语法糖示例:

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const count = ref(0);
    const message = ref('Hello Vue 3 + Composition API');

    function increment() {
      count.value++;
    }

    return {
      count,
      message,
      increment
    };
  }
};
</script>

        在这个例子中,setup() 定义了一个响应式的 count 变量一个 message 变量,以及一个 increment 方法。这些变量和方法将被暴露给模板使用。


setup() 的返回值
        setup() 函数的返回值会被合并到组件实例的公共作用域中,这意味着你可以在模板中直接访问这些返回的变量和函数。


setup() 的注意事项

  • setup() 函数只能在 <script setup> 语法糖中省略 return 关键字。在普通 <script> 标签中,你必须明确返回一个对象,其中包含你希望在模板中访问的所有属性和方法。
  •  setup() 函数不能访问 this 上的任何属性或方法,因为 this 在 setup() 执行时还未被创建。
  •  如果你使用了 props,确保在 setup(props) 中正确地接收并使用它们。

<script setup> 语法糖
        Vue 3 引入了 <script setup>,这是一种新的脚本标签,允许你直接在 <script setup> 标签内部定义和使用组合 API 的功能,而无需显式返回一个对象。这使得代码更加简洁和直接

Vue3 使用setup语法糖示例:

<template>
  <div>
    <p>{{ message }}</p>
    <button @click="increment">Increment</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const count = ref(0);
const message = ref('Hello Vue 3 + Composition API');

function increment() {
  count.value++;
}
</script>

ref和reative主要区别

示例代码:

ref
<template>
  <div>
    Count is: {{ count }}
    <button @click="increment">Increment</button>
  </div>
</template>


<script setup>
import { ref } from 'vue';
const count = ref(0);

// 修改ref的值
function increment() {
   count.value++;
}

</script>
reactive
<template>
  <div>
    Count is: {{ state.count }}
    Name is: {{ state.name }}
    <button @click="increment">Increment</button>
  </div>
</template>


<script setup>
import { reactive } from 'vue';


// 创建一个复杂类型的响应式对象
const state = reactive({
  count: 0,
  name: 'John Doe'
});

// 修改reactive对象的属性
function increment() {
  state.count++;
}

</script>
  1. 数据类型支持:
    1. ref() 可以用于基本数据类型(如字符串、数字、布尔值)以及复杂数据类型(如对象和数组)。当使用ref()包裹数据时,它会返回一个带有.value属性的对象,这个对象可以被Vue追踪变化。
    2. reactive() 主要用于复杂数据类型,如对象和数组。它直接返回一个响应式的代理对象,不需要通过.value访问。
  2. 访问数据:
    1. 使用ref()创建的数据,需要通过.value属性来访问或修改其内部值。在模板语法中,ref的值会被自动解包,所以不需要显式地使用.value。
    2. 使用reactive()创建的数据可以直接像普通JavaScript对象一样访问和修改
  3. 返回类型:
    1. ref() 返回的是一个特殊的RefImpl对象,这个对象有一个_value属性,实际上是一个由reactive()处理过的代理对象
    2. reactive() 直接返回一个由Proxy处理过的响应式代理对象
  4. 使用场景:
    1. ref() 更适合创建单个变量或需要在组件之间共享的响应式数据。
    2. reactive() 更适合创建包含多个属性的复杂数据结构,如状态管理中的store。
  5. 性能考量:
    1. ref() 在大量数据操作时可能会有性能上的优势,因为它只在实际访问或修改.value时才触发依赖收集和更新。
    2. reactive() 在处理复杂数据结构时可能更直观,但在某些情况下可能需要更多的内存,因为它创建了整个对象的响应式代理。

    小结

选择使用 ref 还是 reactive 取决于具体的应用场景和个人偏好:

  1.  简单的数据绑定和共享,ref是一个好选择(在定义数组时,建议使用ref,从而可避免reactive定义时值修改导致的响应式丢失问题);
  2.  而对于复杂的对象和状态管理,reactive可能更加合适

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

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

相关文章

linux radix-tree 基数树实现详解

radix tree&#xff0c;又称做基数树&#xff0c;是一种适合于构建key(index)与value(item)相关联的数据结构。内核中使用非常广泛。本文主要聚焦linux内核基数树的代码实现,大量注释过的代码。 radix-tree组织结构如下: 1、数据结构 /** The bottom two bits of the slot de…

SQL 针对上面的salaries表emp_no字段创建索引idx_emp_no

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站&#xff0c;这篇文章男女通用&#xff0c;看懂了就去分享给你的码吧。 描述 针对salaries…

LabVIEW滤波器性能研究

为了研究滤波器的滤波性能&#xff0c;采用LabVIEW设计了一套滤波器性能研究系统。该系统通过LabVIEW中的波形生成函数&#xff0c;输出幅值及频率可调的正弦波和白噪声两种信号&#xff0c;并将白噪声与正弦波叠加&#xff0c;再通过滤波器输出纯净的正弦波信号。系统通过FFT&…

RFID技术革新养猪业,构建智能化养殖场

RFID技术作为无线射频识别技术的一种&#xff0c;凭借着非接触、高效识别的特性&#xff0c;在养殖业行业中得到了广泛的应用&#xff0c;为构建智能化、高效化的养殖场提供了强大的技术支持&#xff0c;给传统养殖业带来了一场前所未有的技术变革。以下是RFID技术在养猪行业不…

【Oracle】实验三 Oracle数据库的创建和管理

【实验目的】 掌握Oracle数据库的创建方法使用DBCA创建数据库在数据库中装入SCOTT用户及其表 【实验内容】 使用DBCA创建数据库&#xff0c;名为MYDB&#xff0c;找到其初始化文件(文本型和服务器型文件都要找到)&#xff0c;查看各类默认位置并记录下来(包括物理文件所在目…

SpringBoot源码阅读(8)——系统环境创建

SpringBoot创建系统应用上下文是在run方法&#xff0c;第301行。 ConfigurableEnvironment environment prepareEnvironment(listeners, bootstrapContext, applicationArguments);private ConfigurableEnvironment prepareEnvironment(SpringApplicationRunListeners listen…

windows远程桌面到 Linux系统(Ubuntu:22.04)—— 安装xrdp软件

1、在Linux系统上安装xrdp软件 sudo apt update sudo apt install xrdp2、安装完成后&#xff0c;需要开启xrdp服务 sudo systemctl start xrdp sudo systemctl enable xrdp打印返回 Synchronizing state of xrdp.service with SysV service script with /lib/systemd/system…

【VSCode】设置背景图片

1.下载background插件&#xff1a;拓展程序→background→install安装→设置&#xff1a; 2.点击在 settings.json 中编辑&#xff1a; 3.将settings.json文件中所有代码注释&#xff0c;添加以下代码&#xff1a; {// 是否开启背景图显示"background.enabled": t…

【每天认识一个漏洞】sourcemap文件泄露漏洞

&#x1f31d;博客主页&#xff1a;泥菩萨 &#x1f496;专栏&#xff1a;Linux探索之旅 | 网络安全的神秘世界 | 专接本 | 每天学会一个渗透测试工具 利用工具 油猴脚本sourcemap-searcher或burp hae插件 F12控制台输入sms()如果存在会有提示&#xff0c;然后打开看能够下载…

数字化时代的供应链管理综合解决方案

目录 引言背景与意义供应链管理综合解决方案的目标 &#x1f4c4;供应链管理系统主要功能系统优势 &#x1f4c4;物流管理系统主要功能系统优势 &#x1f4c4;订单管理系统主要功能应用场景 &#x1f4c4;仓储管理系统系统亮点主要功能系统优势 &#x1f4c4;商城管理系统主要功…

【机器学习】独立成分分析(ICA):解锁信号的隐秘面纱

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 独立成分分析&#xff08;ICA&#xff09;&#xff1a;解锁信号的隐秘面纱引言I…

LLM——langchain 与阿里 DashScop (通义千问大模型) 和 DashVector(向量数据库) 结合使用总结

文章目录 前言预览直接调用大模型使用 prompt template格式化输出使用上下文 RAG 增强检索 自定义 langchain AgentPromptTemplate 和 ChatPromptTemplate使用少量示例创建ChatPromptTemplate 前言 langchain 是一个面向大模型开发的框架&#xff0c;其中封装了很多核心组件&a…

旷野之间9 - 如何判断是AI编写的文章

一个人写作 人工智能创作的文章、博客、论文甚至书籍在整个互联网上越来越成为问题。 许多人都不确定如何辨别一件作品是由人工智能还是人类创作的。在这篇文章中&#xff0c;我将向您展示如何区分人类和机器人。 深度与原创性 首先要寻找的线索之一是缺乏深度或原创性。人工…

【以史为镜、以史明志,知史爱党、知史爱国】中华上下五千年之-五代十国

五代十国&#xff08;907年-960年&#xff09;是中国历史上的一段大分裂时期&#xff0c;也是对五代与十国的合称。 五代依次为 梁、 唐、 晋、 汉、 周五个朝代&#xff0c;史称 后梁、 后唐、 后晋、 后汉与 后周。 后梁- 五代第一个朝代 朱全忠&#xff08;朱温&#xff09;…

跨境电商必备技能:掌握亚马逊测评自养号技术

亚马逊自养号的环境搭建是一个至关重要的过程&#xff0c;它直接关系到账号的稳定性和安全性。以下是一个详细的搭建方案&#xff1a; 一、底层环境搭建 设备底层硬件参数的伪装阻断&#xff1a; 通过国外服务器在云端搭建一个安全终端&#xff0c;用于阻断平台对设备底层硬…

(CVPR-2022)利用潜在扩散模型进行高分辨率图像合成

利用潜在扩散模型进行高分辨率图像合成 Title:High-Resolution Image Synthesis with Latent Diffusion Models paper是慕尼黑大学和海德堡大学发表在CVPR 22的工作 paper地址 文章目录 利用潜在扩散模型进行高分辨率图像合成Abstract1. Introduction2. Related Work3. Method3…

开关电源——15种控制模式(1)

关于开关电源的控制模式&#xff0c;TI官网的控制模式快速参考指南有相对全面的归纳和描述&#xff0c;提供了15种不同的控制架构&#xff0c;这些架构涵盖了从基础到高级的多种控制模式&#xff0c;以适应不同的应用需求&#xff0c;如下表所示&#xff1a; 以下是对控制模式相…

css实现3d照片墙

效果图 vue2写法&#xff1a; <template><div class"container"><div class"box"><div class"circle circle1"><img src"../../../assets/images/main/logo.png" alt"" /></div>&l…

OpenCV和PIL进行前景提取

摘要 在图像处理和分析中&#xff0c;前景提取是一项关键技术&#xff0c;尤其是在计算机视觉和模式识别领域。本文介绍了一种结合OpenCV和PIL库的方法&#xff0c;实现在批量处理图像时有效提取前景并保留原始图像的EXIF数据。具体步骤包括从指定文件夹中读取图像&#xff0c…

智慧水利的变革之路:如何通过大数据、物联网和人工智能构建高效、智能、可持续的水利管理新模式

目录 一、引言&#xff1a;智慧水利的时代背景与意义 二、大数据&#xff1a;水利管理的数据基石 &#xff08;一&#xff09;数据收集与整合 &#xff08;二&#xff09;数据分析与挖掘 三、物联网&#xff1a;水利管理的感知神经 &#xff08;一&#xff09;智能感知与监…