Vue3入门

1. 为什么要学 Vue3 ?

Vue3 的优势:

在这里插入图片描述

Vue2 选项式 API vs Vue3 组合式API

在这里插入图片描述
在这里插入图片描述

2. create-vue搭建Vue3项目

2.1 认识 create-vue

create-vue是Vue官方新的脚手架工具,底层切换到了 vite(下一代构建工具),为开发提供极速响应

2.2 使用create-vue创建项目

  1. 前提环境条件
    已安装 16.0 或更高版本的 Node.js
    查看Node.js的版本node -v
  2. 创建一个Vue应用
    npm init vue@latest
    这一指令将会安装并执行 create-vue
    在这里插入图片描述

3. 熟悉项目目录和关键文件

关键文件:

  1. vite.config.js - 项目的配置文件 基于vite的配置
  2. package.json - 项目包文件 核心依赖项变成了 Vue3.x 和 vite
  3. main.js - 入口文件 createApp函数创建应用实例
  4. app.vue - 根组件 SFC单文件组件 script - template - style
    变化一:脚本script和模板template顺序调整
    变化二:模板template不再要求唯一根元素
    变化三:脚本script添加setup标识支持组合式API
  5. index.html - 单页入口 提供id为app的挂载点
    在这里插入图片描述

4. 组合式API - setup选项

4.1 setup选项的写法和执行时机

在这里插入图片描述

4.2 setup选项中写代码的特点

在这里插入图片描述

4.3

在这里插入图片描述

4.4

在这里插入图片描述

小总结

  1. setup选项的执行时机?
    beforeCreate钩子之前 自动执行

  2. setup写代码的特点是什么?
    定义数据 + 函数 然后以对象方式return

5. 组合式API - reactive和ref函数

5.1 reactive()

作用:接受对象类型数据的参数传入并返回一个响应式的对象
核心步骤:

<script setup>
//导入
import { reactive } from 'vue'

//执行函数 传入参数 变量接收
const state = reactive(对象类型)
</script>
  1. 从 vue 包中导入 reactive 函数
  2. <script setup>执行 reactive 函数并传入类型为对象的初始值,并使用变量接收返回值

5.2 ref()

作用:接收简单类型或者对象类型的数据传入并返回一个响应式的对象
核心步骤:

<script setup>
//导入
import { ref } from 'vue'

//执行函数 传入参数 变量接收
const state = ref(简单类型或者复杂类型数据)
</script>
  1. 从 vue 包中导入 ref 函数

小总结

  1. reactive和ref函数的共同作用是什么 ?
    用函数调用的方式生成响应式数据

  2. reactive vs ref ?

    1. reactive不能处理简单类型的数据
    2. ref参数类型支持更好但是必须通过.value访问修改
    3. ref函数的内部实现依赖于reactive函数
  3. 在实际工作中推荐使用哪个?
    推荐使用ref函数,更加灵活统一

6. 组合式API - computed

6.1 computed计算属性函数

计算属性基本思想和Vue2的完全一致,组合式API下的计算属性只是修改了写法
核心步骤: 1. 导入computed函数
2. 执行函数 在回调参数中return基于响应式数据做计算的值,用变量接收
在这里插入图片描述
在这里插入图片描述

<script setup>
// const 计算属性 = computed(() => {
  // return 计算返回的结果
// }

import { computed,ref } from 'vue';

// 声明数据
const list = ref([1,2,3,4,5,6,7,8])

// 基于list派生一个计算属性,从list中过滤出 >2
const computedList = computed(() =>{
  return list.value.filter(item => item >2)
})

</script>

<template>
  <div>原始数据:{{ list }}</div>
  <div>计算后的数据:{{ computedList }}</div>
</template>

最佳实践

  1. 计算属性中不应该有“副作用”
    比如异步请求/修改dom

  2. 避免直接修改计算属性的值
    计算属性应该是只读的,特殊情况可以配置 get set

7. 组合式API - watch

7.1 watch函数

作用: 侦听一个或者多个数据的变化,数据变化时执行回调函数
俩个额外参数:1. immediate(立即执行) 2. deep(深度侦听)

7.2 基础使用

7.2.1 基础使用 - 侦听单个数据

  1. 导入watch函数
  2. 执行watch函数传入要侦听的响应式数据(ref对象)和回调函数
    在这里插入图片描述

7.2.2 基础使用 - 侦听多个数据

说明:同时侦听多个响应式数据的变化,不管哪个数据变化都需要执行回调
在这里插入图片描述

7.2.3 基础使用 - immediate

说明:在侦听器创建时立即触发回调, 响应式数据变化之后继续执行回调
在这里插入图片描述

7.2.4 基础使用 - deep

默认机制:通过watch监听的ref对象默认是浅层侦听的,直接修改嵌套的对象属性不会触发回调执行,需要开启deep选项

在这里插入图片描述

精确侦听对象的某个属性

需求:在不开启deep的前提下,侦听age的变化,只有age变化时才执行回调
在这里插入图片描述

小总结

  1. 作为watch函数的第一个参数,ref对象需要添加.value吗?
    不需要,第一个参数就是传 ref 对象
  2. watch只能侦听单个数据吗?
    单个 或者 多个
  3. 不开启deep,直接监视 复杂类型,修改属性 能触发回调吗?
    不能,默认是浅层侦听
  4. 不开启deep,精确侦听对象的某个属性?
    可以把第一个参数写成函数的写法,返回要监听的具体属性

8. 组合式API - 生命周期函数

8.1 Vue3的生命周期API (选项式 VS 组合式)

在这里插入图片描述

8.2 生命周期函数基本使用

  1. 导入生命周期函数
  2. 执行生命周期函数 传入回调
    在这里插入图片描述

8.3 执行多次

生命周期函数是可以执行多次的,多次执行时传入的回调会在时机成熟时依次执行
在这里插入图片描述

小总结

  1. 组合式API中生命周期函数的格式是什么?
    on + 生命周期名字
  2. 组合式API中可以使用onCreated吗?
    没有这个钩子函数,直接写到setup中
  3. 组合式API中组件卸载完毕时执行哪个函数?
    onUnmounted

9. 组合式API - 父子通信

9.1 组合式API下的父传子

基本思想

  1. 父组件中给子组件绑定属性
  2. 子组件内部通过props选项接收
    在这里插入图片描述
    defineProps 原理:就是编译阶段的一个标识,实际编译器解析时,遇到后会进行编译转换
    在这里插入图片描述

9.2 组合式API下的子传父

基本思想

  1. 父组件中给子组件标签通过@绑定事件
  2. 子组件内部通过 emit 方法触发事件
    在这里插入图片描述

小总结

父传子

  1. 父传子的过程中通过什么方式接收props?
    defineProps( { 属性名:类型 } )
  2. setup语法糖中如何使用父组件传过来的数据?
    const props = defineProps( { 属性名:类型 } )
    props.xxx

子传父

  1. 子传父的过程中通过什么方式得到emit方法?
    defineEmits( [‘事件名称’] )
  2. 怎么触发事件
    emit(‘自定义事件名’, 参数)

10. 组合式API - 模版引用

10.1 模板引用的概念

通过ref标识获取真实的dom对象或者组件实例对象 this .$refs .form.validate()

10.2 如何使用(以获取dom为例 组件同理)

  1. 调用ref函数生成一个ref对象
  2. 通过ref标识绑定ref对象到标签
    在这里插入图片描述

10.3 defineExpose()

默认情况下在

小总结

  1. 获取模板引用的时机是什么?
    组件挂载完毕
  2. defineExpose编译宏的作用是什么?
    显式暴露组件内部的属性和方法

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Vue3】keep-alive 缓存组件

当在 Vue.js 中使用 <keep-alive> 组件时&#xff0c;它将会缓存动态组件&#xff0c;而不是每次渲染都销毁和重新创建它们。这对于需要在组件间快速切换并且保持组件状态的情况非常有用。 <keep-alive> 只能包含&#xff08;或者说只能渲染&#xff09;一个子组件…

SQL-每日一题【1484. 按日期分组销售产品】

题目 表 Activities&#xff1a; 编写解决方案找出每个日期、销售的不同产品的数量及其名称。 每个日期的销售产品名称应按词典序排列。 返回按 sell_date 排序的结果表。 结果表结果格式如下例所示。 示例 1: 解题思路 前置知识 group_concat函数的功能   将group by产生的…

Linux 基础篇(六)sudo和添加信任用户

一、sudo 1.是什么&#xff1f; 给被信任的普通用户授权&#xff0c;让被信任的普通用户能执行root用户才能执行的命令的一个命令。 2.为什么&#xff1f; 很多时候我们要在被信任的普通用户下执行一些root用户才能执行的命令&#xff0c;如 yum… 所以需要有一个命令能给普通用…

C字符串与C++ string 类:用法万字详解(上)

目录 引言 一、C语言字符串 1.1 创建 C 字符串 1.2 字符串长度 1.3 字符串拼接 1.4 比较字符串 1.5 复制字符串 二、C字符串string类 2.1 解释 2.2 string构造函数 2.2.1 string() 默认构造函数 2.2.2 string(const char* s) 从 C 风格字符串构造 2.2.3 string(co…

【计算机网络】——数据链路层

二、组帧 1、字符计数法 帧头部使用一个字符来表示帧的大小(包括第一个计数字符) &#xff08;此处一字符一个字节&#xff09; 2、字符填充收尾定界法 特定字符来定界帧的首和尾。若帧中数据段出现等同于特定字符的字符内容&#xff0c;前置一个转义字符。(类似于正则表达…

块、行内块水平垂直居中

1.定位实现水平垂直居中 <div class"outer"><div class"test inner1">定位实现水平垂直居中</div></div><style>.outer {width: 300px;height: 300px;border: 1px solid gray;margin: 100px auto 0;position: relative;}.te…

特征选择 | 变量重要性衡量

特征选择 | 变量重要性衡量 目录 特征选择 | 变量重要性衡量写在前面常规方法存在问题解决策略参考资料 写在前面 特征选择是预测模型构建的关键步骤&#xff0c;旨在1&#xff09;降低数据维度&#xff0c;减少计算量&#xff1b;2&#xff09;剔除一些无关或冗余变量&#xf…

科大讯飞分类算法挑战赛2023的一些经验总结

引言: ResNet是he kaiming大佬的早年神作&#xff0c;当年直接刷榜各大图像分类任务。ResNet是一种残差网络&#xff0c;咱们可以把它理解为一个子网络&#xff0c;这个子网络经过堆叠可以构成一个很深的网络&#xff0c;而ResNext在其基础上&#xff0c;进行了一定修改完善&am…

七、解析应用程序——枚举内容与功能

文章目录 1、web抓取2、发现隐藏内容2.1 蛮力技巧2.2 通过公布的内容进行推测2.3 利用公共信息 3、应用程序页面和功能路径4、发现隐藏参数 攻击应用程序的第一步是收集和分析与其有关的一些关键信息&#xff0c;以清楚了解攻击目标。解析过程首先是枚举应用程序的内容与功能&a…

QT学习笔记-QT安装oracle oci驱动

QT学习笔记-QT安装oracle oci驱动 0、背景1、环境以及条件说明2、编译驱动2.1 下载oracle instant client2.2 编译qt oci驱动2.2.1 修改oci.pro2.2.2 MinGW64构建套件编译2.2.3 MSVC2019_64构建套件编译 3、访问数据库运行成功 0、背景 在使用QT开发应用的过程中&#xff0c;往…

分布式搜索ElasticSearch-ES(一)

一、ElasticSearch介绍 ES是一款非常强大的开源搜索引擎&#xff0c;可以帮我们从海量的数据中快速找到我们需要的内容。 ElasticSearch结合kibana、Logstash、Beats&#xff0c;也就是elastic stack(ELK)&#xff0c;被广泛运用在日志数据分析&#xff0c;实时监控等领域。 …

国产航顺HK32F030M: 内部参考电压

HK32F030MF4P6 用户手册 内部参考电压 adc.c #include "bsp_adc.h"/*** brief ADC GPIO 初始化* param 无* retval 无*/ static void ADCx_GPIO_Config(void) {GPIO_InitTypeDef GPIO_InitStructure;// 打开 ADC IO端口时钟ADC_GPIO_AHBxClock_FUN ( ADC_GPIO_C…

MySQL~事务的四大特性和隔离级别

事务的四大特性 1.原子性&#xff1a;一个事务&#xff08;transaction&#xff09;中的所有操作&#xff0c;要么全部完成&#xff0c;要么全部不完成。事务在执行过程中发生错误&#xff0c;会被回滚&#xff08;Rollback&#xff09;到事务开始前的状态&#xff0c;就像这个…

Linux 终端命令之文件浏览(2) more

Linux 文件浏览命令 cat, more, less, head, tail&#xff0c;此五个文件浏览类的命令皆为外部命令。 hannHannYang:~$ which cat /usr/bin/cat hannHannYang:~$ which more /usr/bin/more hannHannYang:~$ which less /usr/bin/less hannHannYang:~$ which head /usr/bin/he…

初学vue3时应该注意的几个问题

初学vue3时应该注意的几个问题 声明响应式 响应式数据的声明在vue2的时候很简单&#xff0c;在data中声明就行了。但现在可以使用多个方式。 reactive用于声明Object, Array, Map, Set; ref用于声明String, Number, Boolean 使用reactive来声明基础数据类型&#xff08;Str…

SpringCloud实用篇3----Docker

1.初识Docker 1.1 什么是Docker 微服务虽然具备各种各样的优势&#xff0c;但服务的拆分通用给部署带来了很大的麻烦。 分布式系统中&#xff0c;依赖的组件非常多&#xff0c;不同组件之间部署时往往会产生一些冲突。在数百上千台服务中重复部署&#xff0c;环境不一定一致…

使用关键词一站式精准搜索指定期刊或会议论文集中的论文

问题描述 如题&#xff0c;例如&#xff0c;想要找点某主题的相关文献&#xff0c;当然要看本领域权威刊物了&#xff0c;假如你想从CCF人工智能类A级期刊找点文本相似度的论文&#xff0c;逐个点开期刊主页进行搜索&#xff0c;那就有点繁琐&#xff0c;不是一站式。 解决方…

APP外包开发的H5开发框架

跨平台移动应用开发框架允许开发者使用一套代码在多个操作系统上构建应用程序&#xff0c;从而节省时间和资源。以下是一些常见的跨平台移动应用开发框架以及它们的特点&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0…

neo4j的CQL命令实例演示

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

大数据-玩转数据-Redis 安装与使用

一、说明 大多数企业都是基于Linux服务器来部署项目&#xff0c;而且Redis官方也没有提供Windows版本的安装包。因此课程中我们会基于Linux系统来安装Redis. 此处选择的Linux版本为CentOS 7. Redis的官方网站地址&#xff1a;http://download.redis.io/releases 二、下载 m…