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()格式起作用的范例,沒辦法,只好把兩個文件中的父組件、子組件逐一比對,前后費了不少時間,終于找到了問題所在。
我在前面練習(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中顏色的色塊有兩個。
附:vue3 :deep() 深度選擇器使用
#swiper >.swiperContext :deep(p) { width: 100vw; height:60vw; background: #000; border:5px solid; box-sizing: border-box; color: #fff; border-radius: 5%; }
總結(jié)
到此這篇關(guān)于Vue3樣式滲透之deep()為什么無效的文章就介紹到這了,更多相關(guān)Vue3樣式滲透deep()無效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue模擬數(shù)據(jù),實現(xiàn)路由進入商品詳情頁面的示例
今天小編就為大家分享一篇Vue模擬數(shù)據(jù),實現(xiàn)路由進入商品詳情頁面的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08vue中axios處理http發(fā)送請求的示例(Post和get)
本篇文章主要介紹了vue中axios處理http請求的示例(Post和get),這里整理了詳細(xì)的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10深入理解Vue父子組件生命周期執(zhí)行順序及鉤子函數(shù)
本文通過實例代碼給大家介紹了Vue父子組件生命周期執(zhí)行順序及鉤子函數(shù)的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧2018-08-08