Vue3在css中使用js變量及其原理解讀
Vue3在css中使用js變量及其原理解讀
實(shí)現(xiàn)原理
首先css中是有變量的,可以像js變量一樣在style中使用,然后Vue3支持將js中的變量傳入style中,相當(dāng)于在css中創(chuàng)建了同名的變量,值綁定到j(luò)s變量上,后續(xù)會(huì)跟著js中的變量一同響應(yīng)式變化。
CSS變量介紹
CSS變量的聲明方式:
--color: red;
CSS變量的使用方式:
h1 {
color: var(--color);
}作用域:
body {
--color: red;
}
h1 {
color: var(--color); /** 這里獲取到的是全局聲明的變量,值為red **/
}
div {
--color: blue;
color: var(--color); /** 這里獲取到的是局部聲明的變量,值為blue **/
}變量的作用域就是它所在的選擇器的有效范圍。
默認(rèn)值:
div { width: var(–width, 100px) }
假如沒(méi)有定義 --width 變量,那么就會(huì)取第二個(gè)參數(shù)的值,這就很適合我們用來(lái)封裝組件。
在 vue3 的 <style> 中使用 <script> 里的變量的方式
創(chuàng)建一個(gè) vite 項(xiàng)目(vue-cli創(chuàng)建的不可):
npm init vite-app vars
項(xiàng)目初始化
編寫(xiě)代碼:
<template>
<h1>Vue</h1>
</template>
<script>
export default {
data () {
return {
border: '1px solid black',
color: 'red'
}
}
}
</script>
<style vars="{ border, color }" scoped>
h1 {
color: var(--color);
border: var(--border);
}
</style>且在style中的變量也是響應(yīng)式的。
原理:vue控制的是元素的style屬性,使其動(dòng)態(tài)變化。
使用全局變量的方式:
<style vars="{ color }" scoped>
h1 {
color: var(--global:color);
}
</style>兼容性:不兼容IE
vue3中css使用script中定義的變量
代碼
<template>
<div class="box">haha</div>
</template>
<script setup lang="ts">
const boxWidth = '500px'
</script>
<style lang="scss">
.box {
width: v-bind(boxWidth);
height: 200px;
background-color: red;
}
</style>效果

到此這篇關(guān)于Vue3在css中使用js變量及其原理解讀的文章就介紹到這了,更多相關(guān)vue3在css中使用js變量?jī)?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue.js自定義組件directives的實(shí)例代碼
這篇文章主要介紹了vue.js自定義組件directives的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11
Vue2.0 v-for filter列表過(guò)濾功能的實(shí)現(xiàn)
今天小編就為大家分享一篇Vue2.0 v-for filter列表過(guò)濾功能的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
使用vue.js實(shí)現(xiàn)checkbox的全選和多個(gè)的刪除功能
這篇文章主要介紹了使用vue.js實(shí)現(xiàn)checkbox的全選和多個(gè)的刪除功能,需要的朋友可以參考下2017-02-02
django使用channels2.x實(shí)現(xiàn)實(shí)時(shí)通訊
這篇文章主要介紹了django使用channels2.x實(shí)現(xiàn)實(shí)時(shí)通訊,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
vue el-table實(shí)現(xiàn)自定義表頭
這篇文章主要為大家詳細(xì)介紹了vue el-table實(shí)現(xiàn)自定義表頭,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
詳解element-ui日期時(shí)間選擇器的日期格式化問(wèn)題
這篇文章主要介紹了詳解element-ui日期時(shí)間選擇器的日期格式化問(wèn)題,本文用到了DateTimePicker來(lái)選擇日期時(shí)間,但是在將數(shù)據(jù)傳回后臺(tái)的過(guò)程中遇到了一些令人頭疼的問(wèn)題,有興趣的一起來(lái)了解一下2019-04-04
Vue預(yù)渲染:prerender-spa-plugin生成靜態(tài)HTML與vue-meta-info更新meta
Vue.js中,prerender-spa-plugin和vue-meta-info插件的結(jié)合使用,提供了解決SEO問(wèn)題的方案,prerender-spa-plugin通過(guò)預(yù)渲染技術(shù)生成靜態(tài)HTML,而vue-meta-info則能動(dòng)態(tài)管理頁(yè)面元數(shù)據(jù),本文將探討如何使用這兩個(gè)工具優(yōu)化Vue.js項(xiàng)目的SEO表現(xiàn),包括安裝、配置及注意事項(xiàng)2024-10-10

