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>