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