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

vue3 Class 與 Style 綁定操作方法

 更新時(shí)間:2024年05月29日 10:53:02   作者:Qayrup  
數(shù)據(jù)綁定的一個(gè)常見需求場(chǎng)景是操縱元素的 CSS class 列表和內(nèi)聯(lián)樣式,因?yàn)?nbsp;class 和 style 都是 attribute,我們可以和其他 attribute 一樣使用 v-bind 將它們和動(dòng)態(tài)的字符串綁定,這篇文章主要介紹了vue3 Class 與 Style 綁定操作方法,需要的朋友可以參考下

Class 與 Style 綁定

數(shù)據(jù)綁定的一個(gè)常見需求場(chǎng)景是操縱元素的 CSS class 列表和內(nèi)聯(lián)樣式。因?yàn)?class 和 style 都是 attribute,我們可以和其他 attribute 一樣使用 v-bind 將它們和動(dòng)態(tài)的字符串綁定。但是,在處理比較復(fù)雜的綁定時(shí),通過拼接生成字符串是麻煩且易出錯(cuò)的。因此,Vue 專門為 class 和 style 的 v-bind 用法提供了特殊的功能增強(qiáng)。除了字符串外,表達(dá)式的值也可以是對(duì)象或數(shù)組。

綁定 HTML class

綁定對(duì)象?

我們可以給 :class (v-bind:class 的縮寫) 傳遞一個(gè)對(duì)象來動(dòng)態(tài)切換 class:

上面的語法表示 active 是否存在取決于數(shù)據(jù)屬性 isActive 的真假值。

你可以在對(duì)象中寫多個(gè)字段來操作多個(gè) class。此外,:class 指令也可以和一般的 class attribute 共存。舉例來說,下面這樣的狀態(tài):

渲染的結(jié)果會(huì)是:

當(dāng) isActive 或者 hasError 改變時(shí),class 列表會(huì)隨之更新。舉例來說,如果 hasError 變?yōu)?true,class 列表也會(huì)變成 “static active text-danger”。

綁定的對(duì)象并不一定需要寫成內(nèi)聯(lián)字面量的形式,也可以直接綁定一個(gè)對(duì)象:

最終渲染,和內(nèi)聯(lián)對(duì)象沒差別

我們也可以綁定一個(gè)返回對(duì)象的計(jì)算屬性。這是一個(gè)常見且很有用的技巧:

渲染結(jié)果也別無二致

綁定數(shù)組?

我們可以給 :class 綁定一個(gè)數(shù)組來渲染多個(gè) CSS class:

其渲染結(jié)果為

如果你也想在數(shù)組中有條件地渲染某個(gè) class,你可以使用三元表達(dá)式:

errorClass 會(huì)一直存在,但 activeClass 只會(huì)在 isActive 為真時(shí)才存在。

然而,這可能在有多個(gè)依賴條件的 class 時(shí)會(huì)有些冗長(zhǎng)。因此也可以在數(shù)組中嵌套對(duì)象:

渲染結(jié)果如下

在組件上使用

對(duì)于只有一個(gè)根元素的組件,當(dāng)你使用了 class attribute 時(shí),這些 class 會(huì)被添加到根元素上并與該元素上已有的 class 合并。

舉例來說,如果你聲明了一個(gè)組件名叫 helloWorld,模板如下:

在使用時(shí)添加一些 class:

渲染出的 HTML 為:

Class 的綁定也是同樣的:

渲染結(jié)果為

如果你的組件有多個(gè)根元素,你將需要指定哪個(gè)根元素來接收這個(gè) class。你可以通過組件的 $attrs 屬性來指定接收的元素:

這將被渲染為:

你可以在另一篇文章vue3 透?jìng)?Attribute 一章中了解更多組件的 attribute 繼承的細(xì)節(jié)。

綁定內(nèi)聯(lián)樣式

綁定對(duì)象?

:style 支持綁定 JavaScript 對(duì)象值,對(duì)應(yīng)的是 HTML 元素的 style 屬性:

將被渲染為

盡管推薦使用 camelCase,但 :style 也支持 kebab-cased 形式的 CSS 屬性 key (對(duì)應(yīng)其 CSS 中的實(shí)際名稱),例如:

直接綁定一個(gè)樣式對(duì)象通常是一個(gè)好主意,這樣可以使模板更加簡(jiǎn)潔:

渲染結(jié)果一樣


同樣的,如果樣式對(duì)象需要更復(fù)雜的邏輯,也可以使用返回樣式對(duì)象的計(jì)算屬性。這里就不再作演示了

綁定數(shù)組?

我們還可以給 :style 綁定一個(gè)包含多個(gè)樣式對(duì)象的數(shù)組。這些對(duì)象會(huì)被合并后渲染到同一元素上:

渲染結(jié)果為

自動(dòng)前綴?

當(dāng)你在 :style 中使用了需要瀏覽器特殊前綴的 CSS 屬性時(shí),Vue 會(huì)自動(dòng)為他們加上相應(yīng)的前綴。Vue 是在運(yùn)行時(shí)檢查該屬性是否支持在當(dāng)前瀏覽器中使用。如果瀏覽器不支持某個(gè)屬性,那么將嘗試加上各個(gè)瀏覽器特殊前綴,以找到哪一個(gè)是被支持的。

樣式多值?

你可以對(duì)一個(gè)樣式屬性提供多個(gè) (不同前綴的) 值,舉例來說:

<div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

數(shù)組僅會(huì)渲染瀏覽器支持的最后一個(gè)值。在這個(gè)示例中,在支持不需要特別前綴的瀏覽器中都會(huì)渲染為 display: flex。

到此這篇關(guān)于vue3 Class 與 Style 綁定操作方法的文章就介紹到這了,更多相關(guān)vue3 Class 與 Style 綁定內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue.js教程之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)膶W(xué)習(xí)實(shí)踐

    Vue.js教程之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)膶W(xué)習(xí)實(shí)踐

    這篇文章主要給大家介紹了Vue.js之a(chǎn)xios與網(wǎng)絡(luò)傳輸?shù)南嚓P(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟隨小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-04-04
  • 使用vue-i18n?入口文件配置控制臺(tái)報(bào)警問題解決

    使用vue-i18n?入口文件配置控制臺(tái)報(bào)警問題解決

    這篇文章主要介紹了使用vue-i18n?入口文件配置控制臺(tái)報(bào)警問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Vue編寫炫酷的時(shí)鐘插件

    Vue編寫炫酷的時(shí)鐘插件

    這篇文章主要為大家詳細(xì)介紹了Vue編寫炫酷的時(shí)鐘插件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • vue3使用vis繪制甘特圖制作timeline可拖動(dòng)時(shí)間軸及時(shí)間軸中文化(推薦)

    vue3使用vis繪制甘特圖制作timeline可拖動(dòng)時(shí)間軸及時(shí)間軸中文化(推薦)

    這篇文章主要介紹了vue3使用vis繪制甘特圖制作timeline可拖動(dòng)時(shí)間軸,時(shí)間軸中文化,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • vue中引用swiper輪播插件的教程詳解

    vue中引用swiper輪播插件的教程詳解

    這篇文章主要介紹了vue中引用swiper輪播插件的方法,在需要使用swiper的組件里引入swiper,swiper的初始化放在mounted里。具體實(shí)例代碼大家跟隨腳本之家小編一起看看吧
    2018-08-08
  • vue中keep-alive組件的用法示例

    vue中keep-alive組件的用法示例

    眾所周知keep-alive是Vue提供的一個(gè)抽象組件,主要是用來對(duì)組件進(jìn)行緩存,從而做到節(jié)省性能,這篇文章主要給大家介紹了關(guān)于vue中keep-alive組件用法的相關(guān)資料,需要的朋友可以參考下
    2021-05-05
  • vue中可以綁定多個(gè)事件嗎

    vue中可以綁定多個(gè)事件嗎

    這篇文章主要介紹了vue中可以綁定多個(gè)事件嗎,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue之使用echarts圖表setOption多次很卡問題及解決

    vue之使用echarts圖表setOption多次很卡問題及解決

    這篇文章主要介紹了vue之使用echarts圖表setOption多次很卡問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 自定義elementui上傳文件以及攜帶參數(shù)問題

    自定義elementui上傳文件以及攜帶參數(shù)問題

    這篇文章主要介紹了自定義elementui上傳文件以及攜帶參數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • vue路由切換時(shí)取消之前的所有請(qǐng)求操作

    vue路由切換時(shí)取消之前的所有請(qǐng)求操作

    這篇文章主要介紹了vue路由切換時(shí)取消之前的所有請(qǐng)求操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09

最新評(píng)論