React中如何設(shè)置多個className
React設(shè)置多個className
在一個元素上設(shè)置樣式,有一個固定的樣式,然后還有一個使用三元運算符根據(jù)條件添加的樣式。
比如說有一個固定樣式"title":
<div className="title">標題</div>
然后還要一個點擊高亮的樣式:
<div className={index === this.state.active ? "active" : null}>標題</div>
不能這樣寫:
<div className="title" className={index === this.state.active ? "active" : null}>標題</div>
方法一:ES6 模板字符串 ``
className={`title ${index === this.state.active ? 'active' : ''}`}
方法二:join("")
className={["title", index === this.state.active?"active":null].join(' ')}
方法三:classnames(需要下載classnames)
const classNames = require('classnames'); ? const Button = React.createClass({ ? // ... ? render () { ? ? const btnClass = classNames({ ? ? ? btn: true, ? ? ? 'btn-pressed': this.state.isPressed, ? ? ? 'btn-over': !this.state.isPressed && this.state.isHovered ? ? }); ? ? return <button className={btnClass}>{this.props.label}</button>; ? } });
個人喜好 第二種,一方面代碼量少,另一方面方便對 className數(shù)組的增加與刪除。
React className的寫法
本文中展示的,都是多className情況下的寫法,提供的寫法都是筆者個人的一些經(jīng)驗總結(jié),并不一定是最標準的寫法,但是符合高內(nèi)聚,低耦合的工程思想。
(ps:csdn里貌似 jsx 的代碼高亮有些問題,我就用模板字符串包住了)
模板字符串的寫法
//寫法一 export default class A extends Component { state ={ work: true, sabbatical: false, } render(){ return ( `<div className={`calend-item ${work ? '' : "off-day"} ${sabbatical ? "sabbatical" : ''}`} > {/*...............*/} </div >` ) } } //寫法二 export default class B extends Component { state ={ work: true, sabbatical: false, } render(){ return ( `<div className={` 'calend-item' ${work ? '' : "off-day"} ${sabbatical ? "sabbatical" : ''} `} > {/*...............*/} </div >` ) } }
寫法一:模板字符串非折疊的寫法,不僅代碼看起來非常的惡心,而且萬一少一個空格隔開,是沒有錯誤提示的(這點是最致命的),同時最后render出的html結(jié)構(gòu)中還會帶來無意義的空格(見下圖 )。
寫法二:模板字符串折疊的寫法,雖然代碼看起來清楚了些也不會少敲空格,但是最后render出的html結(jié)構(gòu)中不僅有空格,還有換行(見下圖)顯然是顧此失彼。
formatClass的方法
顯然模板字符串帶來了很多的麻煩。
既然className本質(zhì)上就是要得到一個字符串,那么我們就自己寫個方法來得到目標字符串。
//寫法三 export default class A extends Component { state ={ work: true, sabbatical: false, } render(){ //可以將所有的className屬性都塞入下面的對象中 let _class = formatReactClass({ item: [ 'calend-item', work ? null : "off-day", sabbatical ? "sabbatical" : null, ] }) return ( `<div className={_class.item} > {/*...............*/} </div >` ) } } //下面?zhèn)z函數(shù)可以放到自己項目里的工具函數(shù)模塊中 /** * @description: 格式化組件class * @param {Object} classObj * @return {Object} */ function formatReactClass(classObj) { return mapObj(classObj, i => Array.isArray(i) ? i.filter(i => i && i !== '').join(' ') : i ); } /** * @description: map對象 * @param {Object} Obj * @param {Function} callback should be returnable * @return {Object} */ function mapObj(Obj, callback) { let res = {}; Object.keys(Obj).forEach(i => (res[i] = callback(Obj[i]))); return res; }
寫法三:我們將所有的className屬性的值都塞入一個對象中(高內(nèi)聚思想的體現(xiàn)),同時使用formatReactClass工具函數(shù)格式化我們的_class對象。使我們的無論是代碼中,還是最后render出的html結(jié)構(gòu)中的class屬性都十分的規(guī)整。
小結(jié):除了上述寫法、還可以引入如 classnames 等三方的庫來解決問題。筆者的寫法不一定是最好的,但無論是從開發(fā)代碼的規(guī)整度,還是從二次翻閱代碼的舒適度、都是目前個人覺得不錯的一個寫法。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
React?Hooks之usePolymerAction抽象代碼結(jié)構(gòu)設(shè)計理念
這篇文章主要為大家介紹了React?Hooks之usePolymerAction抽象代碼結(jié)構(gòu)設(shè)計理念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09React Native第三方平臺分享的實例(Android,IOS雙平臺)
本篇文章主要介紹了React Native第三方平臺分享的實例(Android,IOS雙平臺),具有一定的參考價值,有興趣的可以了解一下2017-08-08react使用antd-design中select不能及時刷新問題及解決
這篇文章主要介紹了react使用antd-design中select不能及時刷新問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03webpack構(gòu)建react多頁面應(yīng)用詳解
這篇文章主要介紹了webpack構(gòu)建react多頁面應(yīng)用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09React路由的history對象的插件history的使用解讀
這篇文章主要介紹了React路由的history對象的插件history的使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10