VUE3——teleport和suspense

teleport是vue3的内置组件,可以将被包裹的html模板传送到任意位置,to就是要传送到的位置,可以写css选择器。

javascript 复制代码
<div class="dialog">
    <h1>dialog</h1>
    <el-button @click="show = true">打开弹窗</el-button>
    <teleport to='body' >
        <div class="mask" v-show="show">
            <div class="wrapper">
                <h1>我是弹窗</h1>
                <div class="footer">
                    <el-button @click="show = false">关闭弹窗</el-button>
                </div>
            </div>
        </div>
    </teleport>
</div>

Suspense,说到Suspense就必须提一下异步组件。

正常情况下我们一般都是同步引入组件,但在同步引入的情况下,会有个问题,必须等所有的组件全部加载完成之后才会一起显示,例如有个嵌套组件外面几层的组件加载的都很快,但最里面的组件内容很多,加载的慢,但如果同步引入的话,外面的就需要一起等里面的加载完成之后才会一起显示,这样就很慢。异步的话我们就可以让加载好的先显示出来,后面的等加载完再显示。

javascript 复制代码
import { defineAsyncComponent } from "vue"
const child = defineAsyncComponent(()=>import("./child.vue"))

而suspense就是在这种加载异步组件的情况下用上的,它有点类似于elementui的骨架屏,可以让异步组件在加载过程时,等候的过程中先显示一些其他东西,提高用户体验,不至于显示一个空白。

javascript 复制代码
<Suspense>
    <template v-slot:default>
        <child />
    </template>
    <template v-slot:fallback>
        稍等正在加载中.....
    </template>
</Suspense>
相关推荐
T***1607几秒前
Three.js 3D可视化实战,创建交互式3D场景
开发语言·javascript·ecmascript
秋氘渔3 分钟前
Vue基础语法及项目相关指令详解
前端·javascript·vue.js
IT_陈寒5 分钟前
React性能优化实战:我用这5个技巧将组件渲染速度提升了70%
前端·人工智能·后端
邱泽贤12 分钟前
uniapp 当前页调用上一页的方法
前端·javascript·uni-app
不一样的少年_12 分钟前
大部分人都错了!这才是chrome插件多脚本通信的正确姿势
前端·javascript·浏览器
Moment19 分钟前
Angular v21 无 Zone 模式前瞻:新特性、性能提升与迁移方案
前端·javascript·angular.js
yqcoder22 分钟前
vue2 和 vue3 中,provide 和 inject 用法
前端·javascript·vue.js
艾小码22 分钟前
Vue组件开发避坑指南:循环引用、更新控制与模板替代
前端·javascript·vue.js
合作小小程序员小小店27 分钟前
web开发,在线%农业产品销售管理%系统,基于idea,html,css,vue.js,layui,java,jdk,ssm
java·前端·jdk·intellij-idea·layui·数据库管理员
flypwn2 小时前
TFCCTF 2025 WebLess题解
服务器·前端·数据库