詳解Vue中的scoped及穿透方法
scoped的由來
css一直有個(gè)令人困擾的作用域問題:即使是模塊化編程下,在對(duì)應(yīng)的模塊的js中import css進(jìn)來,這個(gè)css仍然是全局的。為了避免css樣式之間的污染,vue中引入了scoped這個(gè)概念。
在vue文件中的style標(biāo)簽上,有一個(gè)特殊的屬性:scoped。當(dāng)一個(gè)style標(biāo)簽擁有scoped屬性時(shí),它的CSS樣式就只能作用于當(dāng)前的組件。通過設(shè)置該屬性,使得組件之間的樣式不互相污染。如果一個(gè)項(xiàng)目中的所有style標(biāo)簽全部加上了scoped,相當(dāng)于實(shí)現(xiàn)了樣式的模塊化。
但是這些樣式又是如何實(shí)現(xiàn)不相互影響呢?
scoped的原理
vue中的scoped 通過在DOM結(jié)構(gòu)以及css樣式上加唯一不重復(fù)的標(biāo)記:data-v-hash的方式,以保證唯一(而這個(gè)工作是由過PostCSS轉(zhuǎn)譯實(shí)現(xiàn)的),達(dá)到樣式私有化模塊化的目的。
總結(jié)一下scoped三條渲染規(guī)則:
- 給HTML的DOM節(jié)點(diǎn)加一個(gè)不重復(fù)data屬性(形如:data-v-19fca230)來表示他的唯一性
- 在每句css選擇器的末尾(編譯后的生成的css語句)加一個(gè)當(dāng)前組件的data屬性選擇器(如[data-v-19fca230])來私有化樣式
- 如果組件內(nèi)部包含有其他組件,只會(huì)給其他組件的最外層標(biāo)簽加上當(dāng)前組件的data屬性
上個(gè)栗子。轉(zhuǎn)譯前:
<style lang="scss" scoped> .test { background: blue; span{ color:red; } } </style> <template> <div class="test"> <span>hello world !</span> </div> </template>
轉(zhuǎn)譯后:
<style lang="css"> .test[data-v-ff86ae42] { background: blue; } .test span[data-v-ff86ae42]{ color: red; } </style> <template> <div class="test" data-v-ff86ae42> <span data-v-ff86ae42>hello world !</span> </div> </template>
可以看出:PostCSS會(huì)給一個(gè)組件中的所有dom添加了一個(gè)獨(dú)一無二的動(dòng)態(tài)屬性data-v-xxxx,然后,給CSS選擇器額外添加一個(gè)對(duì)應(yīng)的屬性選擇器來選擇該組件中dom,這種做法使得樣式只作用于含有該屬性的dom——組件內(nèi)部dom, 從而達(dá)到了'樣式模塊化'的效果.
穿透scoped
但是,在做項(xiàng)目中,會(huì)遇到這么一個(gè)問題,即:引用了第三方組件,需要在組件中局部修改第三方組件的樣式,而又不想去除scoped屬性造成組件之間的樣式污染。那么有哪些解決辦法呢?
- 不使用scoped 省略(個(gè)人不推薦)
- 在模板中使用兩次style標(biāo)簽:
<style lang="scss"> /*添加要覆蓋的樣式*/ </style> <style lang="scss" scoped> /* local styles */ </style> <!--vue官網(wǎng)中提到:一個(gè) .vue 文件可以包含多個(gè)style標(biāo)簽。所以上面的寫法是沒有問題的。-->
穿透scoped >>>
<template> <div class="box"> <dialog></dialog> </div> </template> <!--使用 >>>或者 /deep/ 操作符(Sass 之類的預(yù)處理器無法正確解析 >>>,可以使用/deep/)--> <style lang="scss" scoped> .box { /deep/ input { width: 166px; text-align: center; } } </style> 或者 <style lang="scss" scoped> .box >>> input { width: 166px; text-align: center; } } </style>
希望能幫助遇到同樣問題的你,thanks!
以上所述是小編給大家介紹的Vue中的scoped及穿透方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue響應(yīng)式原理Observer、Dep、Watcher理解
這篇文章主要介紹了Vue響應(yīng)式原理-理解Observer、Dep、Watcher,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法
vue-cli是 vue 官方提供的、快速生成 vue 工程化項(xiàng)目的工具,支持創(chuàng)建vue2和vue3的項(xiàng)目,本文給大家詳細(xì)講解vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法,感興趣的朋友跟隨小編一起看看吧2023-04-04一篇文章告訴你如何實(shí)現(xiàn)Vue前端分頁和后端分頁
這篇文章主要為大家介紹了如何實(shí)現(xiàn)Vue前端分頁和后端分頁,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12如何在vue3中使用滑塊檢驗(yàn)vue-puzzle-verification
這篇文章主要介紹了在vue3中使用滑塊檢驗(yàn)vue-puzzle-verification的相關(guān)資料,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11玩轉(zhuǎn)vue的slot內(nèi)容分發(fā)
這篇文章主要介紹了玩轉(zhuǎn)vue的slot內(nèi)容分發(fā),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09nuxt.js添加環(huán)境變量,區(qū)分項(xiàng)目打包環(huán)境操作
這篇文章主要介紹了nuxt.js添加環(huán)境變量,區(qū)分項(xiàng)目打包環(huán)境操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11Vue 2.0在IE11中打開項(xiàng)目頁面空白的問題解決
這篇文章主要給大家介紹了關(guān)于Vue 2.0在ie 11中打開項(xiàng)目頁面空白問題的解決方法,文中詳細(xì)分析出現(xiàn)該問題的原因,并給出了詳細(xì)的解決方法,需要的朋友可以參考借鑒,下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-07-07