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

vue?scoped與深度選擇器deep的原理分析

 更新時間:2022年10月19日 11:53:02   作者:青天訣  
這篇文章主要介紹了vue?scoped與深度選擇器deep的原理分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

JS引入模塊化概念后,變得更易于開發(fā)維護,但是css樣式由于其特殊性,一直沒有實現(xiàn)模塊化,scoped的出現(xiàn)就是為了實現(xiàn)樣式模塊化,其本質(zhì)利用屬性選擇器實現(xiàn)的一種偽模塊化,并非真正意義上的模塊化,但這已經(jīng)讓css模塊化前進了一大步,要知道JS的模塊化也是以這種方式開始的,比如早期的seajs,requirejs都是利用閉包封裝達到模塊化的效果,后來慢慢的出現(xiàn)了ES6的模塊化規(guī)范import/export,說不定未來的某一天css也會出現(xiàn)真正的模塊化,我們就不用學(xué)習(xí)這種知識點了。

說回正題,該篇文章主要從以下幾個問題,進行探索scoped和deep相關(guān)的實現(xiàn)原理:

  • 1.scoped生成的dom和style有什么特點;
  • 2.父組件引入子組件,生成的dom和style有什么區(qū)別;
  • 3.父組件傳入的子組件slot,生成的dom和style是什么樣的;
  • 4.父組件如何修改子組件的樣式;

scoped的作用

scoped主要用于vue中style部分,加上scoped后,最終生成的dom和style都會被加上一個唯一的動態(tài)屬性,這樣樣式只會對當(dāng)前組件有效,不會污染全局樣式。

如下圖所示:

未加scoped

<template>
    <div class="parent">
        <h1>前端名獅</h1>
    </div>
</template>
<script>
export default {};
</script>
<style lang="less">
.parent {
    color: red;
    h1 {
        font-size: 30px;
    }
}
</style>

加上scoped

<template>
    <div class="parent">
        <h1>前端名獅</h1>
    </div>
</template>
<script>
export default {};
</script>
<style lang="less" scoped>
.parent {
    color: red;
    h1 {
        font-size: 30px;
    }
}
</style>

通過上面兩種情況對比,我們發(fā)現(xiàn):

  • 1.加上scoped后,dom會被添加上一個唯一的屬性值,生成的style樣式也會使用該屬性作為屬性選擇器設(shè)置樣式,這樣使得樣式只對該組件有效,避免了全局樣式污染;
  • 2.每個組件內(nèi)的dom標(biāo)簽都會被設(shè)置上同一個data屬性值;

對于上面兩條規(guī)律,父組件內(nèi)引入子組件的情況下,是否一樣呢?

父組件:

<template>
	<div class="parent">
		<h1>前端名獅</h1>
		<child>
		<div class="time">時間:2020年9月16日</div>
		</child>
	</div>
</template>
<script>
import Child from "./Child.vue";
export default {
  components: {
    Child,
  },
};
</script>
<style lang="less" scoped>
.parent {
	color: red;
	h1 {
		font-size: 30px;
	}
}
</style>

子組件:

<template>
    <div class="child">
        <div class="author">作者:訣九</div>
        <div class="introduce">介紹:定期推送前端技術(shù)相關(guān)文章,面試題詳解</div>
        <slot />
    </div>
</template>
<script>
export default {};
</script>
<style lang="less">
.child {
    font-size: 20px;
    .author {
        font-weight: 600;
        color: red;
    }
    .introduce {
        color: blue;
    }
}
</style>

根據(jù)上圖我們會發(fā)現(xiàn):

  • 1.父組件內(nèi)出現(xiàn)的dom標(biāo)簽都會被添加上同一個屬性值,包括給子組件傳入的slot內(nèi)容;
  • 2.父組件的屬性值只會設(shè)置在子組件的最外層,并不會設(shè)置到子組件的內(nèi)部dom元素上;

常用的組件庫,比如element、vux、vant提供的組件是不帶scoped的。但是我們寫的子組件大部分都是帶有scoped的,看下生成的dom和style如下圖:

deep作用

看到這里,我們清楚了scoped對于生成的dom和style的影響,以及避免全局污染的原理。但是在使用scoped的父組件中如何修改子組件樣式呢?

我們一般會這么寫

<style lang="less" scoped>
.parent {
	color: red;
	h1 {
		font-size: 30px;
	}
	.child {
	    font-size: 20px;
	    .author {
	        color: orange;
	    }
	}
}
</style>

但是最終生成的樣式是以父組件的屬性值作為選擇器的,這樣父組件就只能修改子組件最外層的div樣式,但是修改子組件內(nèi)層元素的樣式是不可行的。

想要修改子組件的內(nèi)層元素樣式,就需要使用/deep/了,/deep/是less中深度選擇器的>的另一種寫法,只是因為>在vue模板中不能正常解析,所以用/deep/代替。

修改下父組件:

<style lang="less" scoped>
.parent {
	color: red;
	h1 {
		font-size: 30px;
	}
/deep/	.child {
	    font-size: 20px;
	    .author {
	        color: orange;
	    }
	}
}
</style>

image

總結(jié)

這個知識點我們經(jīng)常使用,但是很多人卻不知道為什么,實際看下生成的style就知道了。

  • 1.scoped本質(zhì)上是給dom增加一個唯一屬性,然后利用這個屬性作為屬性選擇器設(shè)置樣式達到模塊化的目的(這里的屬性值是vue-template-complier編譯時動態(tài)添加的,具體看源碼);
  • 2./deep/為了解決scoped引發(fā)的父組件修改子組件內(nèi)部樣式問題出現(xiàn)的;

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue項目頁面跳轉(zhuǎn)時瀏覽器窗口上方顯示進度條功能

    Vue項目頁面跳轉(zhuǎn)時瀏覽器窗口上方顯示進度條功能

    這篇文章主要介紹了Vue項目頁面跳轉(zhuǎn)時瀏覽器窗口上方顯示進度條功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • 基于element-ui對話框el-dialog初始化的校驗問題解決

    基于element-ui對話框el-dialog初始化的校驗問題解決

    這篇文章主要介紹了基于element-ui對話框el-dialog初始化的校驗問題解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法

    vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法

    這篇文章主要介紹了vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • vue項目環(huán)境搭建

    vue項目環(huán)境搭建

    這篇文章介紹了vue項目環(huán)境搭建的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • element中datepicker日期選擇器選擇周一到周日并實現(xiàn)上一周和下一周的方法

    element中datepicker日期選擇器選擇周一到周日并實現(xiàn)上一周和下一周的方法

    最近項目中需要用到日期選擇器,所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于element中datepicker日期選擇器選擇周一到周日并實現(xiàn)上一周和下一周的相關(guān)資料,需要的朋友可以參考下
    2023-09-09
  • 解決vue3+vite配置unplugin-vue-component找不到Vant組件

    解決vue3+vite配置unplugin-vue-component找不到Vant組件

    這篇文章主要為大家介紹了vue3+vite配置unplugin-vue-component找不到Vant組件問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • vue動態(tài)代理無須重啟項目解決方案詳解

    vue動態(tài)代理無須重啟項目解決方案詳解

    這篇文章主要為大家介紹了vue動態(tài)代理無須重啟項目解決方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • 前端實現(xiàn)不同角色登入展示不同頁面效果實例

    前端實現(xiàn)不同角色登入展示不同頁面效果實例

    要實現(xiàn)不同角色登錄跳轉(zhuǎn)不同的前端頁面,可以在登錄成功后,根據(jù)用戶的角色信息,使用路由跳轉(zhuǎn)到不同的頁面,這篇文章主要給大家介紹了關(guān)于前端實現(xiàn)不同角色登入展示不同頁面效果的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • vue接入下載文件接口問題

    vue接入下載文件接口問題

    這篇文章主要介紹了vue接入下載文件接口問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 實現(xiàn)elementUI表單的全局驗證的方法步驟

    實現(xiàn)elementUI表單的全局驗證的方法步驟

    這篇文章主要介紹了實現(xiàn)elementUI表單的全局驗證的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評論