欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3在css中使用js變量及其原理解讀

 更新時間:2023年09月13日 14:14:13   作者:靜尾  
這篇文章主要介紹了Vue3在css中使用js變量及其原理解讀,結(jié)合實例代碼介紹了vue3中css使用script中定義的變量的方法,本文給大家介紹的非常詳細,需要的朋友可以參考下

Vue3在css中使用js變量及其原理解讀

實現(xiàn)原理

首先css中是有變量的,可以像js變量一樣在style中使用,然后Vue3支持將js中的變量傳入style中,相當于在css中創(chuàng)建了同名的變量,值綁定到j(luò)s變量上,后續(xù)會跟著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 **/ 
}

變量的作用域就是它所在的選擇器的有效范圍。

默認值:

div { width: var(–width, 100px) }

假如沒有定義 --width 變量,那么就會取第二個參數(shù)的值,這就很適合我們用來封裝組件。

在 vue3 的 <style> 中使用 <script> 里的變量的方式

創(chuàng)建一個 vite 項目(vue-cli創(chuàng)建的不可):

npm init vite-app vars

項目初始化

編寫代碼:

<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屬性,使其動態(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變量內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • axios的攔截請求與響應(yīng)方法

    axios的攔截請求與響應(yīng)方法

    今天小編就為大家分享一篇axios的攔截請求與響應(yīng)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue滑動解鎖組件使用方法詳解

    vue滑動解鎖組件使用方法詳解

    這篇文章主要為大家詳細介紹了vue滑動解鎖組件的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue.js自定義組件directives的實例代碼

    vue.js自定義組件directives的實例代碼

    這篇文章主要介紹了vue.js自定義組件directives的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • Vue2.0 v-for filter列表過濾功能的實現(xiàn)

    Vue2.0 v-for filter列表過濾功能的實現(xiàn)

    今天小編就為大家分享一篇Vue2.0 v-for filter列表過濾功能的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 使用vue.js實現(xiàn)checkbox的全選和多個的刪除功能

    使用vue.js實現(xiàn)checkbox的全選和多個的刪除功能

    這篇文章主要介紹了使用vue.js實現(xiàn)checkbox的全選和多個的刪除功能,需要的朋友可以參考下
    2017-02-02
  • django使用channels2.x實現(xiàn)實時通訊

    django使用channels2.x實現(xiàn)實時通訊

    這篇文章主要介紹了django使用channels2.x實現(xiàn)實時通訊,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 如何在vue 中使用柱狀圖 并自修改配置

    如何在vue 中使用柱狀圖 并自修改配置

    這篇文章主要介紹了如何在vue 中使用柱狀圖 并自修改配置,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01
  • vue el-table實現(xiàn)自定義表頭

    vue el-table實現(xiàn)自定義表頭

    這篇文章主要為大家詳細介紹了vue el-table實現(xiàn)自定義表頭,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • 詳解element-ui日期時間選擇器的日期格式化問題

    詳解element-ui日期時間選擇器的日期格式化問題

    這篇文章主要介紹了詳解element-ui日期時間選擇器的日期格式化問題,本文用到了DateTimePicker來選擇日期時間,但是在將數(shù)據(jù)傳回后臺的過程中遇到了一些令人頭疼的問題,有興趣的一起來了解一下
    2019-04-04
  • Vue預渲染:prerender-spa-plugin生成靜態(tài)HTML與vue-meta-info更新meta

    Vue預渲染:prerender-spa-plugin生成靜態(tài)HTML與vue-meta-info更新meta

    Vue.js中,prerender-spa-plugin和vue-meta-info插件的結(jié)合使用,提供了解決SEO問題的方案,prerender-spa-plugin通過預渲染技術(shù)生成靜態(tài)HTML,而vue-meta-info則能動態(tài)管理頁面元數(shù)據(jù),本文將探討如何使用這兩個工具優(yōu)化Vue.js項目的SEO表現(xiàn),包括安裝、配置及注意事項
    2024-10-10

最新評論