【vue3学习笔记】Suspense组件;vue3中的其它改变

尚硅谷Vue2.0+Vue3.0全套教程丨vuejs从入门到精通

课程 P167节 《Suspense组件》笔记

在这里插入图片描述

想要学习suspense,先来了解静态组件与异步组件。

静态引入与异步引入:

在这里插入图片描述

在network中将网速调慢,观察在静态引入和异步引入模式下,两个组件的加载情况,会发现:静态引入时,两个组件是一起加载出来的;Child组件为异步引入模式下,App组件会先加载完成并呈现,之后Child组件才会加载完成并呈现。

如果采用静态引入方式,当Child组件加载完成前,整个App组件都不会渲染。这样带来的一个问题是:比如页面的组件结构如图中方框所示,嵌套了很多层组件,此时假如最里层的红色框组件加载出现了问题,就会造成所有组件都不会渲染,假如最里层的红色框组件加载缓慢,也会造成所有组件都会等待其加载完成之后才会渲染,就像木桶原理,能装多少水取决于最短的那块木板。什么时候可以展示,取决于最慢的组件。

在这里插入图片描述

而使用异步组件就不会存在这个问题,但异步组件也有一个问题,即先加载完成并呈现的组件可能会让用户认为页面所有元素都已加载完毕,并不知道还有未渲染呈现的部分;而当异步组件加载完成并渲染呈现时,又可能造成页面的抖动。这就造成了不太好的用户体验。

这种场景下,就可以使用Suspense,它是一个内置组件,不需引入,直接使用。它内部原理是使用插槽,内部写好了一个黄色插槽和一个粉色插槽,分别对应正常应该渲染呈现的组件,以及组件未加载完成前呈现的内容。
在这里插入图片描述

Suspense用法如下,default插槽用来定义真正需要呈现的组件;fallback插槽用来定义组件加载完成前呈现的内容:

在这里插入图片描述

此时会发现控制台有个提示:Suspense还在实验中API有可能改变。

在这里插入图片描述

除了网速慢得情况,还有一种情况可以导致组件加载延迟:在setup中返回一个Promise,其中有一个异步操作,一段时间后返回一个值:

在这里插入图片描述

之前讲到setup时曾提到:

在这里插入图片描述

此前不涉及异步组件和sespense时,在正常同步引入组件的情况下,如果在setup中返回一个Promise,会导致返回Promise的整个组件渲染不出来

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

如果一个组件是异步引入的,则这个组件可以在setup中返回一个Promise;也可以用async修饰 setup

在这里插入图片描述

完善之前的知识点:

在这里插入图片描述

课程 P168节 《vue3中的其它改变》笔记

1、全局API的转移

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

2、data选项不能再声明为一个对象;
3、过渡类名更加语义化:

在这里插入图片描述

4、vue3移除了keyCode修饰符,因为其兼容性较差(同时也移除了Vue.config.keyCodes配置);
5、vue3移除了v-on.native修饰符

在这里插入图片描述

在这里插入图片描述

默认情况下,给一个子组件绑定click事件时,vue会默认认为这是一个自定义事件,只有加上 .native 修饰符,告诉vue这是一个原生事件。vue3中移除了 .native 修饰符。

在这里插入图片描述

那么怎么区分绑定在子组件上的事件是原生事件还是自定义事件呢?vue3中的子组件中需要声明自定义事件,通过emits:[‘事件名’] 的形式定义声明自定义事件,未在这里声明的事件即为原生事件:

在这里插入图片描述

6、vue3移除了过滤器:过滤器实现的功能通过methods和computed也可以实现。
在这里插入图片描述

最后,视频课程中老师提到,除了基础知识,到了实际工作岗位上,真实项目中的业务逻辑远远比课程中的练习要复杂得多。因此强大的业务能力也是必需的。

========== 分割线(以下属于个人一点感悟,类似个人日记,不具备知识性与普遍性) =========

说到业务能力,我恍然大悟,一直以来我总认为自己是小白的原因就在于技术不够好,掌握的技术知识不够,实际上业务能力方面更加欠缺且完全没有重视起来,基本上把前端开发只理解成了掌握足够的前端开发框架与知识,所谓的业务能力这一块,完全被我无视了。

这也是造成自己进步缓慢的一个极大原因。怎么提升自己的业务能力?

1、对需求的充分理解,尤其是涉及有业务逻辑的部分,一定要吃透。作为小白总是急于用代码将需求要求的东西实现出来,有时在没有充分理解和吃透需求中的业务逻辑时,对相关代码的逻辑实现也会不好想清楚,写起代码来容易抓瞎;

2、联调和测试的充分与全面。今天日清会,联调的接口展示数据是好的,但全功能从入口进入时,换成了另外的数据,返回字段有的出现问题,导致页面不能正常展示了。所以,联调和测试过程中,一定要多测几条数据、全流程进行测试。不能觉得用一条数据调通了就没有问题了。

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

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

相关文章

CI/CD笔记.Gitlab系列.`gitlab-ci.yml`中的头部关键字

CI/CD笔记.Gitlab系列 gitlab-ci.yml中的头部关键字 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at: https://jclee95.blog.csdn.netMy WebSite:http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csdn.ne…

【MySQL】主从同步原理、分库分表

主从同步原理 1. 主从同步原理 MySQL 经常先把命令拷入硬盘的日志,再执行日志的命令,这样的好处: 日志的位置固定,拷入硬盘的开销不大;将命令先准备好,而不是边读边执行,性能更好,…

Google Genie vs OpenAI Sora:互动世界模型之争,谁将引领AI的未来?

近年来,生成式AI异军突起,从文字到图像,再到视频,它们的创造力令人瞩目。 但今天,我们要介绍Google Genie,不仅仅满足于生成静态的内容。 它能把单一的图片提示,变成一个你可以亲身参与的互动…

【系统分析师】-软件工程

1、信息系统的生命周期 1、四阶段划分 立项阶段:企业全局、形成概念、需求分析。包含【系统分析师】-系统规划-CSDN博客开发阶段:总体规划--系统分析--设计--实施--验收运维阶段:通过验收、移交之后消亡阶段:更新改造、功能扩展…

K8S部署postgresql

(作者:陈玓玏) 一、前置条件 已部署k8s,服务端版本为1.21.14 二、部署postgresql 拉取镜像,docker pull postgres,不指定版本,自动从docker hub拉取最新版本;配置configmap&…

【UE 材质】制作加载图案

目录 效果 步骤 一、形成圆环 二、使圆环转起来 效果 步骤 一、形成圆环 新建一个材质,这里命名为“M_Loading” 打开“M_Loading”,设置混合模式为半透明,着色模型为无光照,勾选双面 下面开始先创建一个圆环,将…

OpenHarmony Docker移植实践

Docker简介 从操作系统诞生之日起,虚拟化技术就不断的演进与发展,结合目前云原生的发展态势,容器无疑是其中的重要一环。 Docker是一个开源的软件项目,可以在Linux操作系统上提供一层额外的抽象,让用户程序部署在一个…

[CSS]文字旁边的竖线以及布局知识

场景:文字前面常见加竖线。 .center-title { 常见内容color: #FFF;font-family: "Source Han Sans CN";font-size: 50px;font-style: normal;font-weight: 700;line-height: normal;position: relative; 要定位left: 16px; 这里是想拉开间距margin-b…

Redisson限流算法

引入依赖 <dependency><groupId>org.redisson</groupId><artifactId>redisson-spring-boot-starter</artifactId><version>3.12.3</version> </dependency>建议版本使用3.15.5以上 使用 这边写了一个demo示例&#xff0c;定…

Vue+Flask电商后台管理系统

在这个项目中&#xff0c;我们将结合Vue.js前端框架和python后端框架Flask&#xff0c;打造一个功能强大、易于使用的电商后台管理系统 项目演示视频&#xff1a; VueFlask项目 目录 前端环境&#xff08;Vue.js&#xff09;&#xff1a; 后端环境&#xff08;python-Flask&…

Mysql REGEXP正则运算符

# 邮箱h开头 mysql> select email form xxx where email REGEXP ^h;

改进的yolo交通标志tt100k数据集目标检测(代码+原理+毕设可用)

YOLO TT100K: 基于YOLO训练的交通标志检测模型 在原始代码基础上&#xff1a; 修改数据加载类&#xff0c;支持CoCo格式&#xff08;使用cocoapi&#xff09;&#xff1b;修改数据增强&#xff1b;validation增加mAP计算&#xff1b;修改anchor&#xff1b; 注: 实验开启weig…

YOLOv9 最简训练教学!

一、代码及论文链接&#xff1a; 代码链接&#xff1a;GitHub - WongKinYiu/yolov9: Implementation of paper - YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information 论文链接&#xff1a;https://arxiv.org/abs/2402.13616 二、使用步骤 1…

淘宝商品数据爬取商品信息采集数据分析API接口详细步骤展示(含测试链接)

01 数据采集 数据采集是数据可视化分析的第一步&#xff0c;也是最基础的一步&#xff0c;数据采集的数量和质量越高&#xff0c;后面分析的准确的也就越高&#xff0c;我们来看一下淘宝网的数据该如何爬取。点此获取淘宝API测试key&密钥 淘宝网站是一个动态加载的网站&a…

前端css、js、bootstrap、vue2.x、ajax查漏补缺(1)

学到的总是忘&#xff0c;遇到了就随手过来补一下 1.【JS】innerHTML innerHTML属性允许更改HTML元素的内容可以解析HTML标签 2.【CSS】display: none 设置元素不可见&#xff0c;不占空间&#xff0c;约等于将元素删除一样&#xff0c;只是源代码还存在 3.【CSS】行内样式 4.【…

工作微信统一管理(还带监管功能)

1.会话页面(可统一管理多个微信号、聚合聊天、手动搜索添加好友、通过验证请求、查看好友的朋友圈等) 2.聊天历史(可查看 所有聊天记录&#xff0c;包括手机.上撤回、删除的消息) 3.群发助手(可以一 -次群发多个好友和群&#xff0c;还可以选择定时发送&#xff0c;目前还在内测…

PlantUML简介

PlantUML简介 plantUML是一款开源的UML图绘制工具&#xff0c;支持通过文本来生成图形&#xff0c;使用起来非常高效。可以支持时序图、类图、对象图、活动图、思维导图等图形的绘制。你可以在IDEA中安装插件来使用PlantUML, 或者在Visual Studio Code中安装插件。 也可以在dra…

数据库|三地五中心,TiDB POC最佳实践探索!

目录 一、POC测试背景 //测试环境信息 二、流量单元化控制 //需求 //解决方案 三、跨城获取TSO的影响与探索 //问题描述与初步分析 //优化方案 四、灾难恢复与流量切流 //需求 //pd leader 切换 //region leader t切换 五、写在最后 一、POC测试背景 在某地震多发省…

sylar高性能服务器-日志(P43-P48)内容记录

文章目录 P43&#xff1a;Hook01一、HOOK定义接口函数指针获取接口原始地址 二、测试 P44-P48&#xff1a;Hook02-06一、hook实现基础二、class FdCtx成员变量构造函数initsetTimeoutgetTimeout 三、class FdManager成员变量构造函数get&#xff08;获取/创建文件句柄类&#x…

mongoDB 优化(1)索引

1、创建复合索引&#xff08;多字段&#xff09; db.collection_test1.createIndex({deletedVersion: 1,param: 1,qrYearMonth: 1},{name: "deletedVersion_1_param_1_qrYearMonth_1",background: true} ); 2、新增索引前&#xff1a; 执行查询&#xff1a; mb.r…