欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 加載遠程組件的解決方案

 更新時間:2023年07月24日 10:28:04   作者:譚光志  
最近的項目有一個加載遠程組件的需求,基于此我對 Vue 加載遠程組件的方案進行了研究,并且整理了兩個可行的解決方案,有感興趣的小伙伴跟著小編一起來看看吧

HTML 文件 + umd 組件

這個方案是最簡單、最容易實現的。組件以 umd 的格式進行打包,然后在 HTML 文件中直接使用。

<div id="app">
    <test-input></test-input>
</div>
<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
<script>
    // 將組件 URL 掛載到 script 標簽上,然后通過 window 獲取這個組件
    await lodaScript('http://localhost/component/input/0.1.0/bundle.js')
    app.component('TestInput', window.TestInput)
</script>

但是這個方案不適合在大型項目中使用,效率比較低。

Vue 工程項目 + esm /umd 組件

Vue 工程項目 + esm /umd 組件是我目前在使用的方案,但是在研究的過程中遇到了兩個問題,逐一解決后,才把這個方案趟通了。

第一個問題 Relative references must start with either "/", "./", or "../"

由于我們的項目不需要兼容 IE,所以打包組件采用的是 esm 格式。打包后的組件源碼如下:

import { reactive } from 'vue'
// other code...

然后在主項目中進行引用:

const { default: TestInput } = await import('http://localhost/component/input/0.1.0/bundle.mjs')

在動態(tài)導入遠程組件到項目時,提示報錯 Relative references must start with either "/", "./", or "../"。這是因為在瀏覽器中不支持以 import { reactive } from 'vue' 的方式進行導入,得把 'vue' 改成 https://..../vue.js 或者 './vue.js' 的形式才可以。平時我們這樣用沒問題是因為有 vite、webpack 等構建工具幫忙解決了這個問題。

第二個問題 Vue 上下文環(huán)境不同

產生上面的問題是因為要引入依賴,如果打包組件時把相關依賴都打在一起,那不就沒有 import 語句了。結果試了一下還是不行,因為當前的 Vue 主項目和打包好的 Vue 組件存在兩個不同的 Vue 上下文。導致在加載組件時報錯,比如提示 xxx 變量找不到 這種問題。

雖然主項目和遠程組件使用的 Vue 方法都是一樣的,但由于各自的 Vue 上下文不一樣,導致主項目無法正常使用遠程組件。

以上兩個問題困擾了我一天的時間,但是睡醒一覺后,終于想到了如何解決這兩個問題。首先在瀏覽器上不能直接使用 import { reactive } from 'vue' 這種語句,那把它改成 const { reactive } = Vue 就能解決這個問題了。至于第二個問題,打包時不把依賴打在一起,而是在 main.js 文件中直接把整個 Vue 引進來:

import * as Vue from 'vue'
window.Vue = Vue

這樣就能確保主項目和遠程組件使用的是同一個 Vue 上下文。

為了解決代碼轉換問題,我寫了一個 rollup-plugin-import-to-const 插件(支持 rollup、vite),打包 esm 組件時,它會自動的把 import { reactive } from 'vue' 轉換成 const { reactive } = Vue 。

至此,就可以在主項目中加載遠程 esm 組件了:

const { default: TestInput } = await import('http://localhost/component/input/0.1.0/bundle.mjs')

其實只要能解決上面的兩個問題,不管是 esm 還是 umd、cjs 等格式,都能夠實現加載遠程組件的方案。比如換成 umd 的格式來打包組件,就不需要引入 rollup 插件去轉換代碼了,并且還能支持 webpack。唯一要做的只是在 main.js 上把 Vue 全引進來掛到 window 下。

import * as Vue from 'vue'
window.Vue = Vue

總結

遠程組件的方案其實不止上面兩種,比如還有直接加載 .vue 文件的方案,有個現成的 vue3-sfc-loader 插件能用。 一般來說,加載遠程組件的應用場景比較少,所以網上能搜到的討論也比較少。目前比較常見的應用場景應該就是在低代碼平臺中加載遠程組件了。

以上就是Vue 加載遠程組件的解決方案的詳細內容,更多關于Vue加載遠程組件的資料請關注腳本之家其它相關文章!

相關文章

  • 一文詳解Vue3的watch是如何實現監(jiān)聽的

    一文詳解Vue3的watch是如何實現監(jiān)聽的

    watch這個API大家都很熟悉,今天這篇文章小編來帶你搞清楚Vue3的watch是如何實現對響應式數據進行監(jiān)聽的,希望對大家有一定的幫助
    2024-11-11
  • 如何在Vue單頁面中進行業(yè)務數據的上報

    如何在Vue單頁面中進行業(yè)務數據的上報

    為什么要在標題里加上一個業(yè)務數據的上報呢,因為在咱們前端項目中,可上報的數據維度太多,比如還有性能數據、頁面錯誤數據、console捕獲等。這里我們只講解業(yè)務數據的埋點。
    2021-05-05
  • 淺析vue中的組件傳值

    淺析vue中的組件傳值

    這篇文章主要介紹了淺析vue中的組件傳值,文章基于vue的相關資料展開對主題的詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-04-04
  • Vue自定義模態(tài)對話框彈窗

    Vue自定義模態(tài)對話框彈窗

    這篇文章主要為大家詳細介紹了Vue自定義模態(tài)對話框彈窗,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 解決vue scoped html樣式無效的問題

    解決vue scoped html樣式無效的問題

    這篇文章主要介紹了解決vue scoped html樣式無效的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • Vue常見組件間通信方案及典型應用場景詳解

    Vue常見組件間通信方案及典型應用場景詳解

    這篇文章主要為大家介紹了Vue常見組件間通信方案及典型應用場景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue3中defineEmits與defineProps的用法實例

    vue3中defineEmits與defineProps的用法實例

    這篇文章主要介紹了vue3中defineEmits/defineProps的用法實例,需要的朋友可以參考下
    2023-12-12
  • 使用webpack搭建vue項目及注意事項

    使用webpack搭建vue項目及注意事項

    這篇文章主要介紹了使用webpack搭建vue項目的方法,本文以開發(fā)環(huán)境為例,通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • vue實現長圖垂直居上 vue實現短圖垂直居中

    vue實現長圖垂直居上 vue實現短圖垂直居中

    這篇文章主要為大家詳細介紹了vue彈性布局實現長圖垂直居上,vue實現短圖垂直居中,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • vue 單元測試初探

    vue 單元測試初探

    這篇文章主要介紹了vue 單元測試的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-04-04

最新評論