亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue中的scoped及穿透方法

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

scoped的由來

css一直有個令人困擾的作用域問題:即使是模塊化編程下,在對應(yīng)的模塊的js中import css進(jìn)來,這個css仍然是全局的。為了避免css樣式之間的污染,vue中引入了scoped這個概念。

在vue文件中的style標(biāo)簽上,有一個特殊的屬性:scoped。當(dāng)一個style標(biāo)簽擁有scoped屬性時,它的CSS樣式就只能作用于當(dāng)前的組件。通過設(shè)置該屬性,使得組件之間的樣式不互相污染。如果一個項目中的所有style標(biāo)簽全部加上了scoped,相當(dāng)于實現(xiàn)了樣式的模塊化。

但是這些樣式又是如何實現(xiàn)不相互影響呢?

scoped的原理

vue中的scoped 通過在DOM結(jié)構(gòu)以及css樣式上加唯一不重復(fù)的標(biāo)記:data-v-hash的方式,以保證唯一(而這個工作是由過PostCSS轉(zhuǎn)譯實現(xiàn)的),達(dá)到樣式私有化模塊化的目的。

總結(jié)一下scoped三條渲染規(guī)則:

  1. 給HTML的DOM節(jié)點加一個不重復(fù)data屬性(形如:data-v-19fca230)來表示他的唯一性
  2. 在每句css選擇器的末尾(編譯后的生成的css語句)加一個當(dāng)前組件的data屬性選擇器(如[data-v-19fca230])來私有化樣式
  3. 如果組件內(nèi)部包含有其他組件,只會給其他組件的最外層標(biāo)簽加上當(dāng)前組件的data屬性

上個栗子。轉(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會給一個組件中的所有dom添加了一個獨一無二的動態(tài)屬性data-v-xxxx,然后,給CSS選擇器額外添加一個對應(yīng)的屬性選擇器來選擇該組件中dom,這種做法使得樣式只作用于含有該屬性的dom——組件內(nèi)部dom, 從而達(dá)到了'樣式模塊化'的效果.

穿透scoped

但是,在做項目中,會遇到這么一個問題,即:引用了第三方組件,需要在組件中局部修改第三方組件的樣式,而又不想去除scoped屬性造成組件之間的樣式污染。那么有哪些解決辦法呢?

  1. 不使用scoped 省略(個人不推薦)
  2. 在模板中使用兩次style標(biāo)簽:
<style lang="scss">
  /*添加要覆蓋的樣式*/
</style>
<style lang="scss" scoped>
  /* local styles */
</style>
<!--vue官網(wǎng)中提到:一個 .vue 文件可以包含多個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及穿透方法詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Vue響應(yīng)式原理Observer、Dep、Watcher理解

    Vue響應(yīng)式原理Observer、Dep、Watcher理解

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

    vue-cli是什么及創(chuàng)建vue-cli項目的方法

    vue-cli是 vue 官方提供的、快速生成 vue 工程化項目的工具,支持創(chuàng)建vue2和vue3的項目,本文給大家詳細(xì)講解vue-cli是什么及創(chuàng)建vue-cli項目的方法,感興趣的朋友跟隨小編一起看看吧
    2023-04-04
  • 一篇文章告訴你如何實現(xiàn)Vue前端分頁和后端分頁

    一篇文章告訴你如何實現(xiàn)Vue前端分頁和后端分頁

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

    如何在vue3中使用滑塊檢驗vue-puzzle-verification

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

    在vue2.x里面簡單使用socketio問題

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

    vue axios請求攔截實例代碼

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

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

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

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

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

    Vue 2.0在IE11中打開項目頁面空白的問題解決

    這篇文章主要給大家介紹了關(guān)于Vue 2.0在ie 11中打開項目頁面空白問題的解決方法,文中詳細(xì)分析出現(xiàn)該問題的原因,并給出了詳細(xì)的解決方法,需要的朋友可以參考借鑒,下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • vue實現(xiàn)div單選多選功能

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

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

最新評論