亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue新增內(nèi)置組件的使用

 更新時間:2021年12月10日 16:02:18   作者:Gorit  
這篇文章主要為大家介紹了Vue新增內(nèi)置組件的使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

一、Teleport

Teleport 官方文檔

1.1 Teleport 介紹

1.Vue 鼓勵我們通過將 UI 和相關(guān)行為封裝到組件中來構(gòu)建我們的 UI。我們可以將它們相互嵌套以構(gòu)建構(gòu)成應用程序 UI 的樹。

2.但是,有時組件模板的一部分在邏輯上屬于該組件,而從技術(shù)角度來看,最好將模板的這部分移動到 DOM 中的其他位置,即 Vue 應用程序之外。

上面的話是不是看起來很懵逼,其實是翻譯自 官方文檔

其實我理解的 Teleport 就是將一個組件掛載在 Vue app 之外,我們知道,Vue 屬于 SPA(單頁面)應用。所有的渲染都在 id 為 app 的標簽里面,這樣的話,我們就創(chuàng)建一個和 app 是同級 的組件,并且通過 teleport 標簽引用,就可以任意頁面使用了

1.2 使用 Teleport

1.我們這里也是實現(xiàn)一個全局模態(tài)框

2.通過 父子組件通信 機制,來使用 teleport 的掛載的特性

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="icon" href="/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Vite App</title>
  </head>
  <body>
    <div id="app"></div>
    <div id="modal"></div> <!-- 定義一個和 app 同級的標簽 modal -->
    <script type="module" src="/src/main.ts"></script>
  </body>
</html>

定義一個 Modal 組件

<template>
	<!-- teleport 有個一個 to 屬性,掛載在 id為modal的標簽上 -->
    <teleport to="#modal">
        <div id="center" v-if="isOpen">
            <div class="modal-header" v-if="title">
                <h2>{{ title }}</h2>
                <hr />
            </div>
            <div class="modal-content">
                <!-- 我們使用插槽,來支持外部插入內(nèi)容 -->
                <slot></slot>
            </div>
            <button @click="buttonClick">Close</button>
        </div>
    </teleport>
</template>
<script lang="ts">
// defineProps<{ msg: string }>() Vue3 setup 定義 props
import { defineComponent } from 'vue';
export default defineComponent({
    props: {
        isOpen: Boolean,
        title: String
    },
    // 驗證
    emits: {
        'close-modal': null
        // (payload: any) => {
        //     return payload.type === 'close'
        // }
    },
    setup(props, context) {
        const buttonClick = () => {
            context.emit('close-modal');
        }
        return {
            buttonClick
        }
    }
});
</script>
<style>
#center {
    width: 200px;
    height: 200px;
    border: 2px solid black;
    background-color: white;
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
</style>

3.使用 Modal 組件

<script setup lang="ts">
import { ref } from 'vue';
import Modal from './components/Modal.vue';
const modalTitle = ref('你好,世界');
const modalIsOpen = ref(false);
const openModal = () => {
  modalIsOpen.value = true;
}
const onModalClose = () => {
  modalIsOpen.value = false;
}
</script>
<template>
  <img alt="Vue logo" src="./assets/logo.png" />
  <div class="test-useURLLoader">
    <button @click="openModal">modal</button>
    <Modal :title="modalTitle" :isOpen="modalIsOpen" @close-modal="onModalClose">
      My modal
    </Modal>
  </div>
</template>
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

1.3 預覽效果

請?zhí)砑訄D片描述

二、Suspense

Suspense 官方文檔

Waring:作為 Vue3 中實驗性的功能,隨時都有可能修改,所以不建議用于生成環(huán)境的應用

2.1 介紹 Suspense

是可以用來異步數(shù)據(jù),它擁有一個本地的處理方法用來適配多種情形提供了二選一(加載完成 和 失敗的插槽)

更詳細的內(nèi)容大家可以自行翻閱官方文檔,我只是進行一部分的挑選

2.2 使用 Suspense

1.為了實現(xiàn)異步效果,我們可以使用 Promise 來實現(xiàn)異步操作。

2.我們定義如下組件 AsyncShow.vue 組件

<template>
	<!-- 等待3秒顯示數(shù)據(jù) -->
    <h1>{{ result }}</h1>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
export default defineComponent({
    setup() {
        return new Promise((resolve) => {
            setTimeout(() => {
                return resolve({
                    result: 43
                })
            }, 3000);
        });
    }
});
</script>
<style>
</style>

3.在 App.vue 里面使用該組件

<script setup lang="ts">
import AsyncShow from './components/AsyncShow.vue';
</script>
<template>
  <img alt="Vue logo" src="./assets/logo.png" />
  <div class="test-useURLLoader">
    <!-- Promise 未執(zhí)行完成時,就會顯示 Loding... 執(zhí)行完畢后,就會顯示數(shù)值 -->
    <Suspense>
      <template #default>
        <AsyncShow />
      </template>
      <template #fallback>
        <h2>
          Loading...
        </h2>
      </template>
    </Suspense>
  </div>
</template>
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

2.3 預覽效果

請?zhí)砑訄D片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • vue實現(xiàn)虛擬列表組件解決長列表性能問題

    vue實現(xiàn)虛擬列表組件解決長列表性能問題

    這篇文章主要介紹了在vue中實現(xiàn)虛擬列表組件,解決長列表性能問題,本文給大家分享實現(xiàn)思路及實例代碼,需要的朋友可以參考下
    2022-07-07
  • Vue.js實現(xiàn)可排序的表格組件功能示例

    Vue.js實現(xiàn)可排序的表格組件功能示例

    這篇文章主要介紹了Vue.js實現(xiàn)可排序的表格組件功能,涉及vue.js事件響應、元素動態(tài)操作、排序、運算等相關(guān)操作技巧,需要的朋友可以參考下
    2019-02-02
  • Vue.js彈出模態(tài)框組件開發(fā)的示例代碼

    Vue.js彈出模態(tài)框組件開發(fā)的示例代碼

    本篇文章主要介紹了Vue.js彈出模態(tài)框組件開發(fā)的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue實現(xiàn)移動端touch拖拽排序

    vue實現(xiàn)移動端touch拖拽排序

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端touch拖拽排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 微信小程序?qū)崙?zhàn)基于vue2實現(xiàn)瀑布流的代碼實例

    微信小程序?qū)崙?zhàn)基于vue2實現(xiàn)瀑布流的代碼實例

    瀑布流,又稱瀑布流式布局,是比較流行的一種網(wǎng)站頁面布局,視覺表現(xiàn)為參差不齊的多欄布局,隨著頁面滾動條向下滾動,這種布局還會不斷加載數(shù)據(jù)塊并附加至當前尾部,這篇文章主要介紹了微信小程序?qū)崙?zhàn),基于vue2實現(xiàn)瀑布流,需要的朋友可以參考下
    2022-12-12
  • vue3的介紹和兩種創(chuàng)建方式詳解(cli和vite)

    vue3的介紹和兩種創(chuàng)建方式詳解(cli和vite)

    這篇文章主要介紹了vue3的介紹和兩種創(chuàng)建方式(cli和vite),vue3對比vue2帶來的性能提升有很多優(yōu)勢,總體來說Vue 3在性能、開發(fā)體驗和代碼組織方面都有所改進,使得它更加適合于大型、復雜的應用程序開發(fā),需要的朋友可以參考下
    2023-04-04
  • Vue父子組件通訊方式及實現(xiàn)方法

    Vue父子組件通訊方式及實現(xiàn)方法

    這篇文章主要介紹了Vue父子組件通訊方式及實現(xiàn)方法,文中通過代碼示例介紹的非常詳細,對我們的學習或工作有一定的幫助,感興趣的同學可以參考閱讀下
    2023-06-06
  • vue實現(xiàn)標簽頁切換/制作tab組件詳細教程

    vue實現(xiàn)標簽頁切換/制作tab組件詳細教程

    在項目開發(fā)中需要使用vue實現(xiàn)tab頁簽切換功能,所以這里總結(jié)下,這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)標簽頁切換/制作tab組件的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • vue時間格式總結(jié)以及轉(zhuǎn)換方法詳解

    vue時間格式總結(jié)以及轉(zhuǎn)換方法詳解

    項目中后臺返回的時間有多種形式,時間戳、ISO標準時間格式等,我們需要轉(zhuǎn)化展示成能看的懂得時間格式,下面這篇文章主要給大家介紹了關(guān)于vue時間格式總結(jié)以及轉(zhuǎn)換方法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • v-for循環(huán)中使用require/import關(guān)鍵字引入本地圖片的幾種方式

    v-for循環(huán)中使用require/import關(guān)鍵字引入本地圖片的幾種方式

    在做項目的過程中,模版相同,可是不標題和圖片不同,循環(huán)標題我們知道可以用v-for循環(huán),可是該怎么引入本地圖片呢?下面這篇文章主要給大家介紹了v-for循環(huán)中使用require/import關(guān)鍵字引入本地圖片的幾種方式,需要的朋友可以參考下
    2021-09-09

最新評論