網站首頁 編程語言 正文
React添加Class的方式
在vue中添加class是一件非常簡單的事情:
你可以通過傳入一個對象, 通過布爾值決定是否添加類:
<button :class="{ active: isFlag, aaa: true}">按鈕</button>
你也可以傳入一個數組:
<!-- 1.基本使用 --> <h2 :class="['aaa', 'bbb']">Hello Vue</h2> <!-- 2.數組中存放變量 --> <h2 :class="[className1, className2]">Hello Vue</h2>
甚至是對象和數組混合使用:
<!-- 數組中放一個對象語法 --> <h2 :class="['aaa', { active: isFlag }]">Hello Vue </h2>
而在React中就相對繁瑣了, React在JSX給了我們開發者足夠多的靈活性,你可以像編寫JavaScript代碼一樣,通過一些邏輯來決定是否添加某些class:
例如用三元運算符判斷是否添加類
<h2 className={`'title' ${isActive ? 'active' : ''}`}>我是標題</h2>
或者將要添加的類放在一個數組中, 在讓數組中的元素使用空格連接
<h2 className={['title', (isActive ? 'active' : '')].join(' ')}>我是標題</h2>
當時如果是簡單的類, 判斷一個類是否添加還是比較容易, 如果需要判斷多個, 處理起來就顯得比較麻煩, 并且代碼的可讀性也會顯得不友好
這個時候我們可以借助于一個第三方的庫:classnames
很明顯,這是一個用于動態添加classnames的一個庫。
首先需要安裝classnames庫:
npm i classnames
classNames 是一個函數, 這個函數接受任意數量的參數,可以是字符串或對象
classNames('foo', 'bar'); // => 'foo bar' classNames('foo', { bar: true }); // => 'foo bar' classNames({ 'foo-bar': true }); // => 'foo-bar' classNames({ 'foo-bar': false }); // => '' classNames({ foo: true }, { bar: true }); // => 'foo bar' classNames({ foo: true, bar: true }); // => 'foo bar classNames('foo', { bar: true, duck: false }, 'baz', { quux: true }); // => 'foo bar baz quux' classNames(null, false, 'bar', undefined, 0, 1, { baz: null }, ''); // => 'bar 1'
示例代碼
render() { const { isActive } = this.state return ( <div> {/* 傳入兩個字符串, 表示綁定兩個class */} <h2 className={classNames("aaa", "bbb")}>標題</h2> {/* 明確綁定aaa類, 根據變量的布爾值決定是否綁定bbb */} <h2 className={classNames("aaa", {bbb: isActive})}>標題</h2> {/* js是無法識別短橫線的, 如果是短橫線連接的類名, 需要用引號包裹 */} <h2 className={classNames({ "aaa-bbb": isActive })}>標題</h2> {/* 有多個不確定是否添加的類名, 可以使用多個對象 */} <h2 className={classNames({aaa: isActive}, {bbb: isActive})}>標題</h2> {/* 也可以寫在一個對象中 */} <h2 className={classNames({aaa: isActive, bbb: isActive})}>標題</h2> {/* 和vue一樣, 也是支持數據的寫法, 以及數組和對象的混合寫法 */} <h2 className={classNames(["aaa", "ccc"])}>標題</h2> <h2 className={classNames(["aaa", {bbb: isActive}])}>標題</h2> </div> ) }
react之中利用第三方庫添加類名classnames
react之中添加動態類名沒有在vue之中那么方便,可以使用第三方庫進行
1、安裝庫
yarn add classnames
2、使用
原生在react之中添加class方法:
<h2 className={"foo bar active"}>1</h2> //下面這個字符串拼接添加類名記得" active"前需要一個空格 <h2 className={'title'+(isActive?" active":"")}>2</h2> //下面就避免上述的還需要加空格 <h2 className={['title',(isActive?"active":"")].join("")}>3</h2>
使用第三方庫
import classNames from "classnames"
//一次多個類名 <h2 className={classNames("foo","bar","active")}>1</h2> //根據變量的真否判斷是否添加類名 <h2 className={classNames({"foo":isFoo,"active":isActive},"bar")}>2</h2> //數組的形式實現 <h2 className={classNames(["title",{"active":isActive}])}>3</h2>
原文鏈接:https://blog.csdn.net/m0_71485750/article/details/126723701
相關推薦
- 2022-09-29 數據設計之權限的實現_數據庫其它
- 2022-04-20 Python?設計模式創建型單例模式_python
- 2021-12-02 C++11標準庫bind函數應用教程_C 語言
- 2022-07-09 Android廣播實現App開機自啟動_Android
- 2022-11-05 Nginx反向代理location和proxy_pass配置規則詳細總結_nginx
- 2022-09-13 Python運算符的應用超全面詳細教程_python
- 2022-07-14 python中序列的逆序方式_python
- 2022-12-09 react?hooks?UI與業務邏輯分離必要性技術方案_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支