亚州天堂爱爱,做爱视频国产全过程在线观看,成人试看30分钟免费视频,女人无遮挡裸交性做爰视频网站

? ? ?

GitHub一篇《Vue 加載遠程組件解決方案》,引起業內大佬點評(vue遠程加載模塊)

背景

最近的項目有一個加載遠程組件的需求?;诖宋覍?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')

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

第二個問題 Vue 上下文環境不同

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

GitHub一篇《Vue 加載遠程組件解決方案》,引起業內大佬點評(vue遠程加載模塊)

雖然主項目和遠程組件使用的 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 加載遠程組件的解決方案
原文鏈接:https://juejin.cn/post/7258850748149219384

版權聲明:本文內容由互聯網用戶自發貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如發現本站有涉嫌抄襲侵權/違法違規的內容, 請發送郵件至 舉報,一經查實,本站將立刻刪除。

(0)
上一篇 2024年5月16日 下午1:04
下一篇 2024年5月16日 下午1:16

相關推薦

  • 黨務公開工作不足

    黨務公開工作不足 黨務公開是中國共產黨的一項重要工作,旨在提高黨的透明度和公信力,增強黨員對黨的認識和忠誠度。然而,在實際操作中,黨務公開工作存在一些不足,需要注意和改進。 黨務公…

    科研百科 2024年11月5日
    5
  • 科研項目驗收和審價

    科研項目驗收和審價是科研項目完成過程中非常重要的環節,它們直接關系到項目的質量和成果。本文將介紹科研項目驗收和審價的基本概念、重要性以及如何進行有效的驗收和審價。 一、科研項目驗收…

    科研百科 2025年3月18日
    0
  • 合同管理風險點有哪些

    合同管理是企業管理中至關重要的一環,合同管理不當可能會導致許多風險點。本文將介紹合同管理風險點,以便企業能夠更好地管理合同,降低風險。 一、合同簽訂 合同簽訂是合同管理的第一步,如…

    科研百科 2024年9月21日
    19
  • 看!兩新黨建踏浪前行

    “科學技術就是第一生產力。在克難攻堅推進項目研發,實現高質量生產的過程中,我們黨員更是要發揮示范作用。”6月29日上班前,在天正電氣溫州智能工廠的車間內,生產經理李永輝為自動化產線…

    科研百科 2023年11月8日
    57
  • 【我為群眾辦實事】警惕!“炒股神器”有貓膩(炒股-我為散戶做主)

    通過炒股實現財富自由 是很多人的夢想 近日 揚州就有一位小伙小蔣 下載了一款“炒股神器” 指望著穩賺不賠 結果卻是血本無歸 小蔣接觸股票已經有兩年多 但總抓不住行情 前不久 他刷短…

    科研百科 2023年5月15日
    194
  • 高校黨建綜述

    高校黨建綜述高校黨建綜述就是由教育部統一印制成的,并通過組建的省份確定,但是院校的要求也是家長們非??粗氐?所以說,家長們一定要重視,并且要讓孩子們能夠了解更多的知識,以此來不斷提…

    科研百科 2024年11月28日
    2
  • 抖音小店如何采集爆款商品?「抖精靈」抖店爆款采集功能詳細教程

    抖音小店商家開店之后,是需要上架產品到抖音小店進行售賣的,選品是一家店成功與否的關鍵,店能不能起來,選品幾乎占了80%的功勞。怎樣在千萬商品中找到一些能幫助自己快速起店的商品,能持…

    科研百科 2023年3月15日
    375
  • 杰青薛鵬求助網絡后續,當局者迷旁觀者清,網友:雙方還需溝通!

    引言 很多人都不知道杰青是什么意思,國家杰出青年科學基金簡稱杰青,而杰青也是該基金獲資助者的代稱! 在大多數人的認知中,博士后都非常了不起了,然而博士后居然是學術底層,真是長見識了…

    科研百科 2024年4月16日
    72
  • 大型項目進度管理

    大型項目進度管理 大型項目進度管理是項目管理中的一個重要環節,對于項目的成功實施至關重要。大型項目通常涉及多個部門和利益相關者,需要協調各種資源和時間,以確保項目在預定時間內完成。…

    科研百科 2024年9月20日
    16
  • 院級科研項目方案

    院級科研項目方案 科研項目是高等教育的重要組成部分,是學校教學科研的的重要途徑。院級科研項目方案是院級科研項目的一個重要組成部分,其制定能夠為科研項目的開展提供指導和支持。本文將介…

    科研百科 2025年2月21日
    3