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

詳解Vue中的scoped及穿透方法

 更新時(shí)間:2019年04月18日 10:22:33   作者:盼你歸來_仍是少年  
這篇文章主要介紹了Vue中的scoped及穿透方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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ī)則:

  1. 給HTML的DOM節(jié)點(diǎn)加一個(gè)不重復(fù)data屬性(形如:data-v-19fca230)來表示他的唯一性
  2. 在每句css選擇器的末尾(編譯后的生成的css語句)加一個(gè)當(dāng)前組件的data屬性選擇器(如[data-v-19fca230])來私有化樣式
  3. 如果組件內(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屬性造成組件之間的樣式污染。那么有哪些解決辦法呢?

  1. 不使用scoped 省略(個(gè)人不推薦)
  2. 在模板中使用兩次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理解

    這篇文章主要介紹了Vue響應(yīng)式原理-理解Observer、Dep、Watcher,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法

    vue-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前端分頁和后端分頁

    這篇文章主要為大家介紹了如何實(shí)現(xiàn)Vue前端分頁和后端分頁,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • 如何在vue3中使用滑塊檢驗(yàn)vue-puzzle-verification

    如何在vue3中使用滑塊檢驗(yàn)vue-puzzle-verification

    這篇文章主要介紹了在vue3中使用滑塊檢驗(yàn)vue-puzzle-verification的相關(guān)資料,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-11-11
  • 在vue2.x里面簡(jiǎn)單使用socketio問題

    在vue2.x里面簡(jiǎn)單使用socketio問題

    這篇文章主要介紹了在vue2.x里面簡(jiǎn)單使用socketio問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue axios請(qǐng)求攔截實(shí)例代碼

    vue axios請(qǐng)求攔截實(shí)例代碼

    axios 是一個(gè)基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端.這篇文章主要介紹了vue/axios請(qǐng)求攔截的相關(guān)知識(shí),需要的朋友可以參考下
    2018-03-03
  • 玩轉(zhuǎn)vue的slot內(nèi)容分發(fā)

    玩轉(zhuǎn)vue的slot內(nèi)容分發(fā)

    這篇文章主要介紹了玩轉(zhuǎn)vue的slot內(nèi)容分發(fā),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • nuxt.js添加環(huán)境變量,區(qū)分項(xiàng)目打包環(huán)境操作

    nuxt.js添加環(huán)境變量,區(qū)分項(xiàng)目打包環(huán)境操作

    這篇文章主要介紹了nuxt.js添加環(huán)境變量,區(qū)分項(xiàng)目打包環(huán)境操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue 2.0在IE11中打開項(xiàng)目頁面空白的問題解決

    Vue 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
  • vue實(shí)現(xiàn)div單選多選功能

    vue實(shí)現(xiàn)div單選多選功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)div單選多選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07

最新評(píng)論