最近在看一篇微前端的文章的時候,看到了這么一個評論,瞬間引起了我的求知欲,這個評論是這樣的:可能有些人不知道微前端是啥,也不知道 主應(yīng)用 和 子應(yīng)用 是啥,我畫一個圖給大加簡單展示一下吧:在這里再說一下 vue 文件" />

AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當(dāng)前位置:首頁 > 科技  > 軟件

Vue 的 style 加了 scoped 也會樣式?jīng)_突?可怕!

來源: 責(zé)編: 時間:2024-03-22 17:42:03 195觀看
導(dǎo)讀太細(xì)了!
最近在看一篇微前端的文章的時候,看到了這么一個評論,瞬間引起了我的求知欲,這個評論是這樣的:可能有些人不知道微前端是啥,也不知道 主應(yīng)用 和 子應(yīng)用 是啥,我畫一個圖給大加簡單展示一下吧:在這里再說一下 vue 文件

太細(xì)了!

最近在看一篇微前端的文章的時候,看到了這么一個評論,瞬間引起了我的求知欲,這個評論是這樣的:oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

可能有些人不知道微前端是啥,也不知道 主應(yīng)用 和 子應(yīng)用 是啥,我畫一個圖給大加簡單展示一下吧:oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

在這里再說一下 vue 文件的 scoped style 是怎么做到樣式隔離的,其實就是 vue解析器 在解析 vue 文件的時候,會通過內(nèi)部的一種計算方法(怎么算的后面會說),給每一個 vue 文件的 html 標(biāo)簽加上 data-v-xxx 這樣的屬性,接著通過屬性選擇器 ,來進(jìn)行樣式隔離,也叫樣式模塊化。oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

回到剛剛那個問題,微前端項目中的 主項目 和 子項目 由于存在了相同相對路徑的 vue 文件,導(dǎo)致了兩個項目的兩個 vue 文件的樣式產(chǎn)生了沖突~oDR28資訊網(wǎng)——每日最新資訊28at.com

所以,我們可以初步知道了,data-v-xxx這個屬性是根據(jù) vue文件相對路徑去計算出來的。但這也只是初步而已,具體我們還得去看一下源碼才行,這樣才能鍛煉我們解決問題的能力~oDR28資訊網(wǎng)——每日最新資訊28at.com

Vue2 和 Vue3 的計算方式大差不差

1.簡單看源碼

先來看看 Webpack + vue-loader 對 Vue2 是怎么處理的,源碼鏈接:https://github.com/vuejs/vue-loader/blob/8357e071c45e77de0889a9feedf2079a327f69d4/src/index.ts#L142oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

再來看看 vite + @vitejs/plugin-vue 對于 Vue3是怎么處理的,源碼鏈接:https://github.com/vitejs/vite-plugin-vue/blob/main/packages/plugin-vue/src/utils/descriptorCache.tsoDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

2.開發(fā)環(huán)境 & 生產(chǎn)環(huán)境

其實兩種的解析方式大差不差,總結(jié)為以下:oDR28資訊網(wǎng)——每日最新資訊28at.com

  • 開發(fā)環(huán)境: 根據(jù)文件的相對路徑進(jìn)行計算data-v-xxx
  • 生產(chǎn)環(huán)境: 根據(jù)與文件的相對路徑 + 文件內(nèi)容進(jìn)行計算 data-v-xxx

所以可以看出在開發(fā)環(huán)境和生產(chǎn)環(huán)境的時候,都有可能兩個 vue 文件的 scoped style 樣式發(fā)生沖,雖然這只是比較邊界的情況~oDR28資訊網(wǎng)——每日最新資訊28at.com

為什么生產(chǎn)環(huán)境不把文件內(nèi)容加入計算呢?我想應(yīng)該是因為開發(fā)階段文件內(nèi)容變化的比較頻繁,所以如果把文件內(nèi)容加入計算的話,勢必會造成構(gòu)建時間的加長。oDR28資訊網(wǎng)——每日最新資訊28at.com

如何防樣式?jīng)_突?

雖然 scoped style 發(fā)生樣式?jīng)_突只是小概率事件,但是我們也得思考一下怎么去避免呢?oDR28資訊網(wǎng)——每日最新資訊28at.com

掘金有一個大佬,給 Vue 官方提了一個 PR,就是在計算 data-v-xxx的時候,加入 package.json 的 name進(jìn)行計算,也就是項目名,這樣能防止兩個不同項目之間的樣式?jīng)_突~oDR28資訊網(wǎng)——每日最新資訊28at.com

大佬牛啊!!!oDR28資訊網(wǎng)——每日最新資訊28at.com

oDR28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-78653-0.htmlVue 的 style 加了 scoped 也會樣式?jīng)_突?可怕!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 為什么都說 HashMap 是線程不安全的?

下一篇: 使用 Node.js 和 htmx 構(gòu)建全棧 CRUD 應(yīng)用程序

標(biāo)簽:
  • 熱門焦點
Top