亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解如何在Vue中動(dòng)態(tài)添加類名

 更新時(shí)間:2022年07月07日 11:19:32   作者:@大遷世界  
本文主要介紹了如何在Vue中動(dòng)態(tài)添加類名,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

能夠向組件添加動(dòng)態(tài)類名是非常強(qiáng)大的功能。它使我們可以更輕松地編寫自定義主題,根據(jù)組件的狀態(tài)添加類,還可以編寫依賴于樣式的組件的不同變體。

添加動(dòng)態(tài)類名與在組件中添加 prop :class="classname"一樣簡(jiǎn)單。無論classname的計(jì)算結(jié)果是什么,都將是添加到組件中的類名。

當(dāng)然,對(duì)于Vue中的動(dòng)態(tài)類,我們可以做的還有很多。在本文中,我們將討論很多內(nèi)容:

  • 在 Vue 中使用靜態(tài)和動(dòng)態(tài)類
  • 如何使用常規(guī)的 JS 表達(dá)式來計(jì)算我們的類
  • 動(dòng)態(tài)類名的數(shù)組語法
  • 對(duì)象語法
  • 快速生成類名
  • 如何在自定義組件上使用動(dòng)態(tài)類名

靜態(tài)和動(dòng)態(tài)類

在Vue中,我們可以向組件添加靜態(tài)類和動(dòng)態(tài)類。

靜態(tài)類是那些永遠(yuǎn)不會(huì)改變的乏味類,它們將始終出現(xiàn)在組件中。另一方面,我們可以在應(yīng)用程序中添加和刪除動(dòng)態(tài)類。

添加靜態(tài)類與在常規(guī)HTML中所做的是完全相同的

<template>
  <span class="description">
    This is how you add static classes in Vue.
  </span>
</template>

動(dòng)態(tài)類非常類似,但是我們必須使用Vue的特殊屬性語法v-bind,以便將 JS 表達(dá)式綁定到我們的類:

<template>
  <span v-bind:class="'description'">
    This is how you add static classes in Vue.
  </span>
</template>

這里你會(huì)注意到,我們必須在動(dòng)態(tài)類名周圍添加額外的引號(hào)。

這是因?yàn)関-bind語法接受我們作為 JS 值傳遞的任何內(nèi)容。添加引號(hào)可以確保Vue將其視為字符串。

Vue還有一個(gè)v-bind的簡(jiǎn)寫語法:

<template>
  <span :class="'description'">
    This is how you add static classes in Vue.
  </span>
</template>

真正奇妙的是,您甚至可以在同一個(gè)組件上同時(shí)擁有靜態(tài)類和動(dòng)態(tài)類。靜態(tài)類用于我們知道不會(huì)更改的內(nèi)容,比如定位和布局,動(dòng)態(tài)類用于主題之類的:

<template>
  <span
    class="description"
    :class="theme"
  >
    This is how you add static classes in Vue.
  </span>
</template>
 
export default {
  data() {
    return {
      theme: 'blue-theme',
    };
  }
};
----------------------------------------
.blue-theme {
  color: navy;
  background: white;
}

在本例中,theme是包含我們將應(yīng)用的類名的變量。

有條件的類名

由于v-bind可以接受任何 JS 表達(dá)式,因此我們可以用它做一些非??岬氖虑椤N易钕矚g的是在模板中使用三元表達(dá)式,它往往是非常干凈和可讀的。

<template>
  <span
    class="description"
    :class="darkMode ? 'dark-theme' : 'light-theme'"
  >
    This is how you add dynamic classes in Vue.
  </span>
</template>

如果darkMode為true,則將dark-theme用作我們的類名。否則,我們選擇light-theme。

使用數(shù)組語法

如果需要?jiǎng)討B(tài)添加許多不同的類,可以使用數(shù)組或?qū)ο?。這兩種方法都很有用,我們先來看數(shù)組方式。

因?yàn)槲覀冎皇窃谟?jì)算一個(gè) JS 表達(dá)式,所以可以將我們剛剛學(xué)到的表達(dá)式與數(shù)組語法結(jié)合起來

<template>
  <span
    class="description"
    :class="[
      fontTheme,
      darkMode ? 'dark-theme' : 'light-theme',
    ]"
  >
    This is how you add dynamic classes in Vue.
  </span>
</template>

我們使用數(shù)組在這個(gè)元素上設(shè)置兩個(gè)動(dòng)態(tài)類名。fontTheme的值是一個(gè)類名,它將改變字體的外觀。在前面的例子中,我們?nèi)匀豢梢允褂胐arkMode變量在dark-theme和light-theme之間切換。

使用對(duì)象語法

我們甚至可以使用對(duì)象來定義動(dòng)態(tài)類的列表,這給了我們更多的靈活性。

對(duì)于任何值為真的鍵/值對(duì),它將把鍵用作類名。讓我們看一個(gè)對(duì)象語法的例子:

<template>
  <span
    class="description"
    :class="{
      'dark-theme': darkMode,
      'light-theme': !darkMode,
    ]"
  >
    This is how you add dynamic classes in Vue.
  </span>
</template>

我們的對(duì)象包含兩個(gè)鍵:dark-theme和light-theme。與我們之前實(shí)現(xiàn)的邏輯類似,我們希望基于darkMode的值在這些主題之間切換。

當(dāng)darkMode為 true 時(shí),會(huì)把dark-theme作為一個(gè)動(dòng)態(tài)類名應(yīng)用于我們的元素。但是light-them不會(huì)被應(yīng)用,因?yàn)?darkMode 值為false。

現(xiàn)在我們已經(jīng)介紹了向Vue組件動(dòng)態(tài)添加類的基礎(chǔ)知識(shí)。那么如何使用自己的自定義組件來做到這一點(diǎn)?

與自定義組件一起使用

假設(shè)我們?cè)?app 中有一個(gè)自定義組件

<template>
  <MovieList
    :movies="movies"
    :genre="genre"
  />
</template>

如果我們要?jiǎng)討B(tài)添加一個(gè)將更改主題的類,我們?cè)撛趺崔k?其實(shí)很簡(jiǎn)單。

我們只需要像以前那樣添加:class屬性

<template>
  <MovieList
    :movies="movies"
    :genre="genre"
    :class="darkMode ? 'dark-theme' : 'light-theme'"
  />
</template>

之所以起作用,是因?yàn)閂ue直接在MovieList的根元素上設(shè)置類。

在組件上設(shè)置props時(shí),Vue會(huì)將這些props與組件在其props部分中指定的props進(jìn)行比較。如果有匹配項(xiàng),它將作為常規(guī)props傳遞。否則,Vue會(huì)將其添加到根DOM元素中。

在這里,由于MovieList沒有指定class屬性,因此Vue知道應(yīng)該在根元素上進(jìn)行設(shè)置。

不過,我們可以用動(dòng)態(tài)類名做一些更高級(jí)的事情。

快速生成類名

我們已經(jīng)介紹了許多動(dòng)態(tài)添加或刪除類名的不同方法。但是動(dòng)態(tài)生成類名本身又如何呢?

假設(shè)有一個(gè)Button組件,它為所有不同類型的按鈕提供20種不同的CSS樣式。

你可能不想花一整天的時(shí)間把每一項(xiàng)都寫出來,也不想把開關(guān)的邏輯都寫出來。相反,我們將動(dòng)態(tài)生成要應(yīng)用的類的名稱。

<template>
  <span
    class="description"
    :class="theme"
  >
    This is how you add static classes in Vue.
  </span>
</template>
 
 
export default {
  data() {
    return {
      theme: 'blue-theme',
    };
  }
};
 
.blue-theme {
  color: navy;
  background: white;
}

我們可以設(shè)置一個(gè)變量來包含我們想要的任何類名的字符串。如果我們想對(duì)Button組件執(zhí)行此操作,則可以執(zhí)行以下簡(jiǎn)單操作:

<template>
  <button
    @click="$emit('click')"
    class="button"
    :class="theme"
  >
    {{ text }}
  </button>
</template>
 
export default {
  props: {
    theme: {
      type: String,
      default: 'default',
    }
  }
};
 
.default {}
 
.primary {}
 
.danger {}

現(xiàn)在,使用Button組件的任何人都可以將theme屬性設(shè)置為他們想要使用的任何主題。

如果沒有設(shè)置任何類,它將添加.default類。如果將其設(shè)置為primary,則會(huì)添加.primary類。

使用計(jì)算屬性來簡(jiǎn)化類

最終,模板中的表達(dá)式將變得過于復(fù)雜,并將開始變得非?;靵y和難以理解。幸運(yùn)的是,我們有一個(gè)簡(jiǎn)單的解決方案,就是使用計(jì)算民屬性:

<template>
  <MovieList
    :movies="movies"
    :genre="genre"
    :class="class"
  />
</template>
 
export default {
  computed: {
    class() {
      return darkMode ? 'dark-theme' : 'light-theme';
    }
  }
};

這不僅易于閱讀,而且還可以輕松添加新功能并在將來進(jìn)行重構(gòu)。

到此這篇關(guān)于詳解如何在Vue中動(dòng)態(tài)添加類名的文章就介紹到這了,更多相關(guān)Vue 動(dòng)態(tài)添加類名內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue之瀏覽器存儲(chǔ)方法封裝實(shí)例

    vue之瀏覽器存儲(chǔ)方法封裝實(shí)例

    下面小編就為大家分享一篇vue之瀏覽器存儲(chǔ)方法封裝實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue-cli3.0如何修改端口號(hào)

    vue-cli3.0如何修改端口號(hào)

    這篇文章主要介紹了vue-cli3.0如何修改端口號(hào),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue首屏?xí)r間指標(biāo)采集最佳方式詳解

    Vue首屏?xí)r間指標(biāo)采集最佳方式詳解

    這篇文章主要為大家介紹了Vue首屏?xí)r間指標(biāo)采集最佳方式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Vue如何引入遠(yuǎn)程JS文件

    Vue如何引入遠(yuǎn)程JS文件

    本篇文章主要介紹了Vue引入遠(yuǎn)程JS文件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-04-04
  • vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法

    vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法

    這篇文章主要介紹了vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue實(shí)現(xiàn)tab切換的放大鏡效果

    vue實(shí)現(xiàn)tab切換的放大鏡效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)tab切換的放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue中正確使用jsx語法的姿勢(shì)分享

    vue中正確使用jsx語法的姿勢(shì)分享

    這篇文章主要給大家介紹了關(guān)于vue中正確使用jsx的相關(guān)資料,JSX就是Javascript和XML結(jié)合的一種格式,React發(fā)明了JSX,利用HTML語法來創(chuàng)建虛擬DOM,當(dāng)遇到<,JSX就當(dāng)HTML解析,遇到{就當(dāng)JavaScript解析,需要的朋友可以參考下
    2021-07-07
  • Vue路由監(jiān)聽實(shí)現(xiàn)同頁面動(dòng)態(tài)加載的示例

    Vue路由監(jiān)聽實(shí)現(xiàn)同頁面動(dòng)態(tài)加載的示例

    本文主要介紹了Vue基于路由監(jiān)聽實(shí)現(xiàn)同頁面動(dòng)態(tài)加載的示例,重點(diǎn)在于切換路由的時(shí)候,重新拉取列表數(shù)據(jù),接下來看看實(shí)現(xiàn)方法吧
    2021-05-05
  • Vue仿手機(jī)qq的實(shí)例代碼(demo)

    Vue仿手機(jī)qq的實(shí)例代碼(demo)

    Vue.js(讀音 /vju&#720;/, 類似于 view) 是一套構(gòu)建用戶界面的漸進(jìn)式框架。這篇文章給大家介紹Vue仿手機(jī)qq的實(shí)例代碼,需要的的朋友參考下吧
    2017-09-09
  • vue ElementUI實(shí)現(xiàn)異步加載樹

    vue ElementUI實(shí)現(xiàn)異步加載樹

    這篇文章主要為大家詳細(xì)介紹了vue ElementUI實(shí)現(xiàn)異步加載樹,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評(píng)論