成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Vue 的 style 加了 scoped,居然也會樣式沖突?

開發 前端
為什么開發環境不把文件內容加入計算呢?我想應該是因為開發階段文件內容變化的比較頻繁,所以如果把文件內容加入計算的話,勢必會造成構建時間的加長。

前言

大家好,我是林三心,用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初心!

太細了!

最近在看一篇微前端的文章的時候,看到了這么一個評論,瞬間引起了我的求知欲,這個評論是這樣的。

圖片圖片

可能有些人不知道微前端是啥,也不知道 主應用 和 子應用 是啥,我畫一個圖給大加簡單展示一下吧::

圖片圖片

在這里再說一下 vue 文件的 scoped style 是怎么做到樣式隔離的,其實就是 vue解析器 在解析 vue 文件的時候,會通過內部的一種計算方法(怎么算的后面會說),給每一個 vue 文件的 html 標簽加上 data-v-xxx 這樣的屬性,接著通過 屬性選擇器 ,來進行樣式隔離,也叫樣式模塊化

圖片圖片

圖片圖片

圖片圖片

回到剛剛那個問題,微前端項目中的 主項目 和 子項目 由于存在了相同相對路徑的 vue 文件,導致了兩個項目的兩個 vue 文件的樣式產生了沖突~

所以,我們可以初步知道了,data-v-xxx這個屬性是根據 vue文件相對路徑去計算出來的。但這也只是初步而已,具體我們還得去看一下源碼才行,這樣才能鍛煉我們解決問題的能力~

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

簡單看源碼

先來看看 Webpack + vue-loader 對 Vue2 是怎么處理的,源碼鏈接:https://github.com/vuejs/vue-loader/blob/8357e071c45e77de0889a9feedf2079a327f69d4/src/index.ts#L142

圖片圖片

再來看看 vite + @vitejs/plugin-vue 對于 Vue3是怎么處理的,源碼鏈接:https://github.com/vitejs/vite-plugin-vue/blob/main/packages/plugin-vue/src/utils/descriptorCache.ts

圖片圖片

開發環境 & 生產環境

其實兩種的解析方式大差不差,總結為以下:

  • 開發環境: 根據文件的相對路徑進行計算data-v-xxx
  • 生產環境: 根據與文件的相對路徑 + 文件內容進行計算 data-v-xxx

所以可以看出在開發環境和生產環境的時候,都有可能兩個 vue 文件的 scoped style 樣式發生沖,雖然這只是比較邊界的情況~

為什么開發環境不把文件內容加入計算呢?我想應該是因為開發階段文件內容變化的比較頻繁,所以如果把文件內容加入計算的話,勢必會造成構建時間的加長。

如何防樣式沖突?

雖然 scoped style 發生樣式沖突只是小概率事件,但是我們也得思考一下怎么去避免呢?

掘金有一個大佬,給 Vue 官方提了一個 PR,就是在計算 data-v-xxx的時候,加入 package.json 的 name進行計算,也就是項目名,這樣能防止兩個不同項目之間的樣式沖突~

大佬牛啊!!!

圖片 圖片

責任編輯:武曉燕 來源: 前端之神
相關推薦

2024-03-22 12:22:50

Vue前端

2024-01-04 08:49:03

Vuescope限制

2020-10-22 08:50:04

Cascading S

2024-06-27 09:24:55

2021-06-09 18:21:20

語法PHP8 \Match

2022-01-07 09:50:51

大數據信息應用

2023-01-03 11:22:23

C#代碼SQL Server

2010-09-14 15:04:42

list-styleCSS

2021-12-28 08:17:41

循環 forgo

2023-08-11 17:42:35

ChatGPT人工智能

2018-08-03 13:06:16

騰訊Facebook社交

2022-08-02 13:32:24

Linux瀏覽器代碼

2009-03-12 09:51:51

職場老板辦公桌

2022-05-13 21:20:23

組件庫樣式選擇器

2022-06-30 12:43:08

寬帶無線接入FWA

2022-08-17 08:17:01

SPI機制接口

2016-07-27 17:16:34

大數據媒體

2020-10-23 08:51:55

CSS

2016-03-01 14:31:19

漏洞iOS設備安全

2010-03-23 16:26:32

無線網卡設備
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 蜜桃黄网 | 天堂va在线观看 | 欧美激情欧美激情在线五月 | 91不卡在线 | 国产精品一级 | 盗摄精品av一区二区三区 | 超碰人人爱 | 日日摸日日爽 | 国产精品一区二区视频 | 日韩在线精品 | 久草热8精品视频在线观看 午夜伦4480yy私人影院 | 日韩欧美国产成人一区二区 | 国产成人精品一区二区三区视频 | 91精品国产综合久久久久 | 在线免费国产视频 | 爱综合| av毛片| 久久中文一区二区 | 一区二区三区四区av | 久久精品亚洲精品国产欧美 | 久久精品亚洲精品 | 91亚洲国产成人精品一区二三 | 国产视频线观看永久免费 | 91久久精品一区二区二区 | 免费激情| 久久久夜 | 亚洲三级国产 | 欧美成人影院在线 | 日韩av大片免费看 | 亚洲高清成人 | 精品久久久久国产免费第一页 | 国产特级毛片aaaaaa | 久久久精彩视频 | 欧美aⅴ片| 国内精品免费久久久久软件老师 | 久久久久久久久精 | 国产一区视频在线 | 国产中文在线观看 | 精品视频一区二区三区在线观看 | 欧美黄视频 | 成人免费视屏 |