Vue3中樣式滲透:deep()無效的原因分析
今天學(xué)習(xí) /deep/ 樣式穿透,因為vue3中已經(jīng)使用:deep()取代了/deep/ ,所以直接用:deep()練習(xí)。
:deep()的使用場景:
如果給當(dāng)前組件的style 節(jié)點添加了scoped 屬性,則當(dāng)前組件的樣式對其子組件是不生效的。如果想讓某些樣式對子組件生效,則需要使用:deep()。
我原本覺得這個沒有難度,于是寫了個案例來驗證。然后問題出現(xiàn)了,:deep()定義的樣式在子組件中不起作用。
我開始找錯,把包括冒號、括號在內(nèi)的語法格式等都檢查了一遍,發(fā)現(xiàn)語法格式?jīng)]有問題,控制臺也不報錯,但是:deep()格式的樣式在子組件中就是無效。
幸好我這兒有一個:deep()格式起作用的范例,沒辦法,只好把兩個文件中的父組件、子組件逐一比對,前后費(fèi)了不少時間,終于找到了問題所在。
我在前面練習(xí)的時候,Vue2.X中要求元素必須在一個根節(jié)點中,Vue3.X無此要求,可以不在一個根節(jié)點中,所以為了驗證這一點,我把外層的
刪去了,果然不報錯。
可是問題就出在這個根節(jié)點上,如果App.vue中沒有這個根節(jié)點,那么:deep()不起作用,我把根節(jié)點加上,:deep()樣式就生效了。
唉,感覺自己被這個根節(jié)點坑了一把。
1.父組件App.vue中代碼
<style lang="less" scoped> :deep(.title3){ background-color:antiquewhite; } </style>
2.子組件中的代碼
<template> <h3 class="title3">受父組件影響的內(nèi)容</h3> </template>
還有一點讓我覺得新鮮,CSS中顏色的色塊有兩個。
到此這篇關(guān)于Vue3中樣式滲透:deep()無效的原因分析的文章就介紹到這了,更多相關(guān)Vue樣式滲透deep內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue從一個頁面跳轉(zhuǎn)到另一個頁面并攜帶參數(shù)的解決方法
這篇文章主要介紹了vue從一個頁面跳轉(zhuǎn)到另一個頁面并攜帶參數(shù)的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08如何使用Vue3+elementPlus的Tree組件實現(xiàn)一個拖拽文件夾管理
最近在做一個文件夾管理的功能,要實現(xiàn)一個樹狀的拖拽文件夾面板,里面包含兩種元素,文件夾以及文件,這篇文章主要介紹了使用Vue3+elementPlus的Tree組件實現(xiàn)一個拖拽文件夾管理?,需要的朋友可以參考下2023-09-09Vue?中如何使用?el-date-picker?限制只能選擇當(dāng)天、當(dāng)天之前或當(dāng)天之后日期的方法詳解
在Vue前端開發(fā)中,使用 el-date-picker 組件進(jìn)行日期選擇是常見的需求,有時候我們需要限制用戶只能選擇當(dāng)天、當(dāng)天之前或當(dāng)天之后的日期,本文將詳細(xì)介紹如何使用 el-date-picker 組件實現(xiàn)這些限制,讓你能夠輕松應(yīng)對各種日期選擇場景,需要的朋友可以參考下2023-09-09在vue中實現(xiàn)給每個頁面頂部設(shè)置title
這篇文章主要介紹了在vue中實現(xiàn)給每個頁面頂部設(shè)置title,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07vue2.x中的provide和inject用法小結(jié)
這篇文章主要介紹了vue2.x中的provide和inject用法小結(jié),本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12