vue3項目怎麼使用樣式穿透修改elementUI預設樣式
一、樣式模組化
在css單檔中,我們在style標籤中寫組件的樣式,可以看到,一般style標籤都會帶上一個scoped屬性,這樣可以實現及時不同組件選擇器一樣,但是樣式互不干擾。
看一個例子,我們在兩個元件中都定義一個hello-world-box
類,在對應的scope標籤中設定不同的樣式。
可以看到,vue為我們在不同的元件中的標籤加上了一個獨有的屬性(PostCSS轉譯實作)
。然後透過屬性選擇器,實現不同屬性的標籤樣式互不干擾。
css屬性選擇器的作用是:為具有特定屬性的 HTML 元素設定樣式
.hello-world-box[data-v-e17ea971] { color: red; }
這也是style標籤scoped屬性實作樣式模組化的原理。
當一個style標籤擁有scoped屬性時,它的CSS樣式就只能作用於目前的組件,也就是說,該樣式只能適用於目前組件元素。透過此屬性,可以使得組件之間的樣式不互相污染。如果一個專案中的所有style標籤全部加上了scoped,相當於實現了樣式的模組化。
二、樣式穿透實作
了解了vue中樣式模組化的實現,進入正題,如何實現自訂elmentUI元件庫中元件的樣式呢?
這其實也是比較常見的需求,因為有的UI圖並不是使用element元件庫的元件畫的,所以樣式上一定有偏差。
我們來看看el-table
可以看到,element元件的樣式都是透過外部樣式檔案實現的,所以對應的標籤上並沒有vue加上的屬性。
那麼我們直接在使用elment元件的元件中加上樣式,是不會生效的,外部匯入的樣式檔案優先權更高。
1、外部css文件
我們可以自己定義一個css文件,然後書寫對應的要修改的樣式。
例如:styles.css
在入口檔main.js中引入:
這裡注意引入elment css檔案和自訂css檔案的引入順序,因為css樣式生效是後來者居上的。
生效了。
但是這樣其實是存在問題的: 樣式檔案影響了所有元件,也就是我們在其他頁面中呼叫這個元件,樣式也被修改了。
解決辦法之一就是在元件對應的類別上在套件上一層自訂的類別名稱。
2、:deep()
:deep()
:改變css解析時私有屬性的位置
.outer { .el-input__inner { // 此时css解析的为 .outer .el-input__inner[data-v-xxxx] 样式无效 background: pink; } :deep(.el-input__inner) { // 此时css解析的为 .outer[data-v-xxxx] .el-input__inner 样式生效 background: red; } }
3、:slotted()
:slotted()
:在子元件定義樣式插槽內容樣式
預設情況下,作用域樣式不會影響到<slot/ >
渲染出來的內容,因為它們被認為是父元件所持有並傳遞進來的。
<template> <div> <slot>插槽</slot> </div> </template> <style lang="less" scoped> :slotted(.red) { color: red; } </style>
4、:global()
:global() :全域選擇器,定義全域樣式,不用單開一個沒有scoped的style。
<style scoped> :global(.red-box) { color: red; } </style> <!-- 等效于 --> <style> .red-box{ color:red } </style>
5、動態css(v-bind)
vue3單一檔案元件的<style>
標籤支援使用v-bind CSS 函數
將CSS 的值連結到動態的元件狀態
,也就是我們可以在style標籤中引入script標籤中的響應式變數:
<template> <el-table :data="tableData" > <el-table-column prop="date" label="Date" width="180" /> <el-table-column prop="name" label="Name" width="180" /> <el-table-column prop="address" label="Address" /> </el-table> </template> <script lang="ts" setup> import { ref } from 'vue'; const tableData = [ { date: '2016-05-03', name: 'Tom', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-02', name: 'Tom', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-04', name: 'Tom', address: 'No. 189, Grove St, Los Angeles', }, { date: '2016-05-01', name: 'Tom', address: 'No. 189, Grove St, Los Angeles', }, ] const redColor = ref('red') </script> <style scoped> .el-table { color: v-bind(redColor); } </style>
可以看到,即使在scoped的style標籤中,樣式穿透也生效了。
實際的值會被編譯成雜湊化的 CSS 自訂屬性,因此 CSS 本身仍然是靜態的。自訂屬性會透過內聯樣式的方式套用到元件的根元素
上,並且在來源值變更的時候會響應式地更新。
以上是vue3項目怎麼使用樣式穿透修改elementUI預設樣式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

tinymce是一個功能齊全的富文本編輯器插件,但在vue中引入tinymce並不像別的Vue富文本插件一樣那麼順利,tinymce本身並不適配Vue,還需要引入@tinymce/tinymce-vue,並且它是國外的富文本插件,沒有透過中文版本,需要在其官網下載翻譯包(可能需要翻牆)。 1.安裝相關依賴npminstalltinymce-Snpminstall@tinymce/tinymce-vue-S2、下載中文包3.引入皮膚和漢化包在項目public資料夾下新建tinymce資料夾,將下載的

想要實現頁面的局部刷新,我們只需要實現局部元件(dom)的重新渲染。在Vue中,想要實現這效果最簡單的方式方法就是使用v-if指令。在Vue2中我們除了使用v-if指令讓局部dom的重新渲染,也可以新建一個空白元件,需要刷新局部頁面時跳轉至這個空白元件頁面,然後在空白元件內的beforeRouteEnter守衛中又跳轉回原來的頁面。如下圖所示,如何在Vue3.X中實現點擊刷新按鈕實現紅框範圍內的dom重新加載,並展示對應的加載狀態。由於Vue3.X中scriptsetup語法中組件內守衛只有o

vue3+vite:src使用require動態導入圖片報錯和解決方法vue3+vite動態的導入多張圖片vue3如果使用的是typescript開發,就會出現require引入圖片報錯,requireisnotdefined不能像使用vue2這樣imgUrl:require(' …/assets/test.png')導入,是因為typescript不支援require所以用import導入,下面介紹如何解決:使用awaitimport

Vue實作部落格前端,需要實作markdown的解析,如果有程式碼則需要實作程式碼的高亮。 Vue的markdown解析函式庫很多,如markdown-it、vue-markdown-loader、marked、vue-markdown等。這些庫都大同小異。這裡選用的是marked,程式碼高亮的函式庫選用的是highlight.js。具體實現步驟如下:一、安裝依賴庫在vue專案下開啟命令窗口,並輸入以下命令npminstallmarked-save//marked用於將markdown轉換成htmlnpmins

前言無論是vue還是react,當我們遇到多處重複程式碼的時候,我們都會想著如何重複使用這些程式碼,而不是一個檔案裡充斥著一堆冗餘程式碼。實際上,vue和react都可以透過抽組件的方式來達到復用,但如果遇到一些很小的程式碼片段,你又不想抽到另外一個檔案的情況下,相比而言,react可以在相同文件裡面宣告對應的小元件,或透過renderfunction來實現,如:constDemo:FC=({msg})=>{returndemomsgis{msg}}constApp:FC=()=>{return(

vue3+ts+axios+pinia實作無感刷新1.先在專案中下載aiXos和pinianpmipinia--savenpminstallaxios--save2.封裝axios請求-----下載js-cookienpmiJS-cookie-s//引入aixosimporttype{AxiosRequestConfigig ,AxiosResponse}from"axios";importaxiosfrom'axios';import{ElMess

最終效果安裝VueCropper組件yarnaddvue-cropper@next上面的安裝值針對Vue3的,如果時Vue2或想使用其他的方式引用,請訪問它的npm官方地址:官方教程。在元件中引用使用時也很簡單,只需要引入對應的元件和它的樣式文件,我這裡沒有在全域引用,只在我的元件檔案中引入import{userInfoByRequest}from'../js/api' import{VueCropper}from'vue-cropper&

使用Vue建構自訂元素WebComponents是一組web原生API的統稱,允許開發者建立可重複使用的自訂元素(customelements)。自訂元素的主要好處是,它們可以在使用任何框架,甚至在不使用框架的場景下使用。當你面向的最終用戶可能使用了不同的前端技術棧,或者當你希望將最終的應用與它使用的組件實現細節解耦時,它們會是理想的選擇。 Vue和WebComponents是互補的技術,Vue為使用和創建自訂元素提供了出色的支援。你可以將自訂元素整合到現有的Vue應用中,或使用Vue來構
