vue 中綁定樣式 【class樣式綁定】

class 樣式綁定

在 Vue 中,可以通過 :class(或簡寫 v-bind:class)實現類名(class)樣式的綁定。Vue 提供了幾種常用的綁定方式,分別支持字符串、對象和數組語法。

綁定字符串

<div :class="'active'"></div>

等價于:

<div class="active"></div>

綁定對象

<div :class="{ active: isActive, 'text-danger': hasError }"></div>
  • 當 isActive 為 true 時,添加類名 active;
  • 當 hasError 為 true 時,添加類名 text-danger。

綁定數組

<div :class="[activeClass, errorClass]"></div>
  • activeClass 和 errorClass 是組件中的數據或計算屬性,如:
data() {return {activeClass: 'active',errorClass: 'text-danger'}
}

混合使用

<div :class="['base-class', { active: isActive, 'text-danger': hasError }]"></div>

示例組件

<template><div :class="['box', { active: isActive }]">Hello</div>
</template><script>
export default {data() {return {isActive: true}}
}
</script><style>
.box { padding: 10px; }
.active { background-color: yellow; }
</style>

再理解class綁定

好的,我們來深入理解 Vue 的 class 樣式綁定機制,包括它的底層原理、動態性、響應式特點,以及實際開發中的高級用法。

? Vue :class 的本質

:class 是 v-bind:class 的簡寫。它的本質是把綁定值“最終轉換為字符串類名”,然后動態地應用到 DOM 元素上。

Vue 會根據你傳入的數據類型,做不同的處理邏輯:

字符串(String)
<div :class="'foo bar'"></div>

Vue 不做處理,直接將字符串 foo bar 設置為 class 屬性值。

對象(Object)
<div :class="{ active: isActive, 'text-danger': hasError }"></div>

底層行為:

  • Vue 遍歷對象的每一個 key。
  • 如果 key 對應的值為 true,則保留這個類名;否則忽略。
  • 最終拼接為字符串。

這是最常見的形式,便于響應式控制類名的添加和移除。

數組(Array)
<div :class="[activeClass, errorClass]"></div>

底層行為:

  • Vue 會遞歸解析數組中的每一項:
  • 如果是字符串:直接添加。
  • 如果是對象:按對象處理方式處理。
  • 如果是數組:繼續遞歸。

適合動態組合多個類,甚至做復雜的條件判斷。

? 響應式原理解析

當綁定的值(如 isActive、activeClass 等)發生變化時,Vue 會自動重新渲染這個節點的 class,因為這些數據是響應式的。Vue 使用了依賴收集和偵聽機制(基于 Proxy 或 Object.defineProperty)確保:

  • 數據改變
  • class 自動更新
  • DOM 自動同步

? 復雜示例:結合計算屬性

<template><div :class="classObject">按鈕</div>
</template><script>
export default {data() {return {isPrimary: true,isDisabled: false}},computed: {classObject() {return {'btn': true,'btn-primary': this.isPrimary,'btn-disabled': this.isDisabled}}}
}
</script>

優勢:邏輯集中在 computed 中,模板更清晰,適合大型項目。

? 實用場景技巧

動態類名前綴

<div :class="`theme-${theme}`"></div>

當 theme = ‘dark’,結果是 class=“theme-dark”。

在組件上綁定類

<MyComponent :class="{ 'highlight': isHighlighted }" />

**注意:**組件必須將類名通過 $attrs 或 inheritAttrs: false 顯式傳遞到內部元素,否則類名不會自動生效。

使用 Tailwind / 原子化 CSS 框架時

你可以靈活使用 :class 和字符串拼接動態控制 Utility 類。

<div :class="['px-4', `text-${textSize}`]"></div>

🔍 小結

類型適合場景Vue處理方式
字符串靜態或直接拼接的類名直接使用
對象通過條件動態啟用/禁用類key-value判斷
數組多個類組合、嵌套判斷復雜遞歸展開、合并類名

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/82925.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/82925.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/82925.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Unity3D 序列化機制:引擎內的應用場景和基本原理

前言 Unity3D 的序列化機制是其核心功能之一&#xff0c;用于在編輯器和運行時之間持久化數據、管理場景狀態、處理預制體&#xff08;Prefab&#xff09;以及實現跨平臺兼容性。以下是其應用場景和基本原理的詳細解析&#xff1a; 對惹&#xff0c;這里有一個游戲開發交流小…

Python 字典鍵 “三變一” 之謎

開頭&#xff1a;讀者的“玄學”字典謎題 上周&#xff0c;朋友發來了一段讓他抓耳撓腮的代碼&#xff1a; >>> {True: foo, 1: bar, 1.0: baz} {True: baz} “我明明定義了布爾True、整數1、浮點數1.0三個鍵&#xff0c;結果字典里只剩True一個鍵&#xff0c;值…

如何選擇 RabbitMQ、Redis 隊列等消息中間件?—— 深度解析與實戰評估

如何選擇 RabbitMQ、Redis 隊列等消息中間件?—— 深度解析與實戰評估 1. 引言 在現代分布式系統架構中,消息隊列(Message Queue,MQ) 作為解耦服務、異步處理和高效通信的關鍵組件,被廣泛應用于高并發、微服務和數據流處理場景。選擇合適的消息中間件不僅能提高系統的穩…

特征工程四:數據特征提取TfidfVectorizer的使用

TfidfVectorizer 深度解析 TfidfVectorizer 是 scikit-learn 中用于文本特征提取的核心工具&#xff0c;它將原始文本轉換為 TF-IDF 特征矩陣&#xff0c;是自然語言處理(NLP)和文本挖掘的基礎組件。 一、核心原理 1. TF-IDF 計算 TF (Term Frequency)&#xff1a;詞頻&…

c/c++爬蟲總結

GitHub 開源 C/C 網頁爬蟲探究&#xff1a;協議、實現與測試 網頁爬蟲&#xff0c;作為一種自動化獲取網絡信息的強大工具&#xff0c;在搜索引擎、數據挖掘、市場分析等領域扮演著至關重要的角色。對于希望深入理解網絡工作原理和數據提取技術的 C/C 開發者&#xff0c;尤其是…

PostgreSQL 的表連接方法

PostgreSQL 的表連接方法 PostgreSQL 提供了多種高效的連接算法&#xff0c;每種方法適用于不同的查詢場景。以下是 PostgreSQL 支持的四種主要表連接方法及其特點&#xff1a; 1 Nested Loop Join&#xff08;嵌套循環連接&#xff09; 工作原理 對外表的每一行&#xff0…

【Qt】qss語法詳解

QSS (Qt Style Sheets) 語法格式詳解 QSS 是 Qt 的樣式表語言&#xff0c;類似于 CSS&#xff0c;用于自定義 Qt 應用程序的外觀。以下是 QSS 的完整語法格式說明&#xff1a; 基本語法結構 selector {property: value;property: value;... }1. 選擇器 (Selectors) 基本選擇…

Azure資源創建與部署指南

本文將指導您如何在Azure平臺上創建和配置必要的資源,以部署基于OpenAI的應用程序。 資源組創建 資源組是管理和組織Azure資源的邏輯容器。 在Azure門戶頂端的查詢框中輸入"Resource groups"(英文環境)或"資源組"(中文環境)在搜索結果中點擊"資…

Java后端快速生成驗證碼

Hutool是一個小而全的Java工具類庫&#xff0c;它提供了很多實用的工具類&#xff0c;包括但不限于日期處理、加密解密、文件操作、反射操作、HTTP客戶端等。 核心工具類&#xff1a;CaptchaUtil&#xff0c;CaptchaUtil 是 Hutool 提供的一個工具類&#xff0c;用于創建各種類…

sql 備份表a數據到表b

備份表a數據到表b mysql CREATE TABLE sys_dict_240702 LIKE sys_dict;INSERT INTO sys_dict_240702 SELECT * FROM sys_dict;mssql select * into t_Dict_240702 from t_Dict

2.4GHz無線通信芯片選型指南:集成SOC與低功耗方案解析

今天給大家分享幾款2.4GHz無線通信芯片方案&#xff1a; 一、集成SOC芯片方案 XL2407P&#xff08;芯嶺技術&#xff09; 集成射頻收發機和微控制器&#xff08;如九齊NY8A054E&#xff09; 支持一對多組網和自動重傳 發射功率8dBm&#xff0c;接收靈敏度-96.5dBm&#xff08…

Tomcat與純 Java Socket 實現遠程通信的區別

Servlet 容器??&#xff08;如 Tomcat&#xff09; 是一個管理 Servlet 生命周期的運行環境&#xff0c;主要功能包括&#xff1a; ??協議解析??&#xff1a;自動處理 HTTP 請求/響應的底層協議&#xff08;如報文頭解析、狀態碼生成&#xff09;&#xff1b; ??線程…

[超級簡單]講解如何用PHP實現LINE Pay API!

在 PHP 中實現 LINE Pay API 之前我應該??做哪些準備&#xff1f;如何在 PHP 中實現 LINE Pay API&#xff1f; 目錄 [前提] 環境使用 PHP 實現 LINE Pay API 的準備工作使用 PHP 實現 LINE Pay API概括 [前提] 環境 這次我們將使用SandBox環境&#xff08;測試環境&a…

centos7.x下,使用寶塔進行主從復制的原理和實踐

操作原理&#xff1a; 一、主庫配置 1.修改 MySQL 配置文件 # 編輯主庫配置文件&#xff08;路徑根據實際系統可能不同&#xff09; vim /etc/my.cnf # 添加以下配置 [mysqld] server-id 1 # 唯一 ID&#xff0c;主庫設置為 1 log-bin mysql-bin …

從零實現基于Transformer的英譯漢任務

1. model.py&#xff08;用的是上一篇文章的代碼&#xff1a;從0搭建Transformer-CSDN博客&#xff09; import torch import torch.nn as nn import mathclass PositionalEncoding(nn.Module):def __init__ (self, d_model, dropout, max_len5000):super(PositionalEncoding,…

c#建筑行業財務流水賬系統軟件可上傳記賬憑證財務管理系統簽核功能

# financial_建筑行業 建筑行業財務流水賬系統軟件可上傳記賬憑證財務管理系統簽核功能 # 開發背景 軟件是給岳陽客戶定制開發一款建筑行業流水賬財務軟件。提供工程簽證單、施工日志、人員出勤表等信息記錄。 # 財務管理系統功能描述 1.可以自行設置記賬科目&#xff0c;做憑…

MySQL 8.0 OCP 1Z0-908 題目解析(2)

題目005 Choose two. Which two actions can obtain information about deadlocks? □ A) Run the SHOW ENGINE INNODB MUTEX command from the mysql client. □ B) Enable the innodb_status_output_locks global parameter. □ C) Enable the innodb_print_all_deadlock…

XA協議和Tcc

基于 XA 協議的兩階段提交 (2PC)。這是一種分布式事務協議&#xff0c;旨在保證在多個參與者&#xff08;通常是不同的數據庫或資源管理器&#xff09;共同參與的事務中&#xff0c;所有參與者要么都提交事務&#xff0c;要么都回滾事務&#xff0c;從而維護數據的一致性。 你…

數據分析-圖2-圖像對象設置參數與子圖

from matplotlib import pyplot as mp mp.figure(A figure,facecolorgray) mp.plot([0,1],[1,2]) mp.figure(B figure,facecolorlightgray) mp.plot([1,2],[2,1]) #如果figure中標題已創建&#xff0c;則不會新建窗口&#xff0c; #而是將舊窗口設置為當前窗口 mp.figure(A fig…

跳轉語句:break、continue、goto -《Go語言實戰指南》

在控制流程中&#xff0c;我們有時需要跳出當前循環或跳過當前步驟&#xff0c;甚至直接跳轉到指定位置。Go 提供了三種基本跳轉語句&#xff1a; ? break&#xff1a;跳出當前 for、switch 或 select。? continue&#xff1a;跳過本輪循環&#xff0c;進入下一輪。? goto&a…