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

React中如何設(shè)置多個className

 更新時間:2023年01月17日 09:06:12   作者:sky_Wolf丶  
這篇文章主要介紹了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è)計理念

    這篇文章主要為大家介紹了React?Hooks之usePolymerAction抽象代碼結(jié)構(gòu)設(shè)計理念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • React Native第三方平臺分享的實例(Android,IOS雙平臺)

    React Native第三方平臺分享的實例(Android,IOS雙平臺)

    本篇文章主要介紹了React Native第三方平臺分享的實例(Android,IOS雙平臺),具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • React 服務(wù)器組件的使用方法詳解

    React 服務(wù)器組件的使用方法詳解

    最近,React 服務(wù)器組件受到了廣泛的關(guān)注和熱捧,這是因為 React 服務(wù)器組件允許開發(fā)人員將與組件相關(guān)的任務(wù)外包給服務(wù)器,在本文中,我們將討論什么是 React 服務(wù)器組件,以及如何將它們集成到構(gòu)建應(yīng)用程序中,需要的朋友可以參考下
    2023-10-10
  • react+antd樹選擇下拉框中增加搜索框

    react+antd樹選擇下拉框中增加搜索框

    這篇文章主要介紹了react+antd樹選擇下拉框中增加搜索框方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 深入淺析React refs的簡介

    深入淺析React refs的簡介

    React中的Refs提供了一種方式,允許我們訪問DOM節(jié)點或在render方法中創(chuàng)建的React元素,本文給大家介紹react refs的相關(guān)知識,感興趣的朋友一起看看吧
    2021-07-07
  • react使用antd-design中select不能及時刷新問題及解決

    react使用antd-design中select不能及時刷新問題及解決

    這篇文章主要介紹了react使用antd-design中select不能及時刷新問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • React的diff算法核心復(fù)用圖文詳解

    React的diff算法核心復(fù)用圖文詳解

    這篇文章主要為大家介紹了React的diff算法核心復(fù)用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • webpack構(gòu)建react多頁面應(yīng)用詳解

    webpack構(gòu)建react多頁面應(yīng)用詳解

    這篇文章主要介紹了webpack構(gòu)建react多頁面應(yīng)用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • React路由的history對象的插件history的使用解讀

    React路由的history對象的插件history的使用解讀

    這篇文章主要介紹了React路由的history對象的插件history的使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 詳解React中合并單元格的正確寫法

    詳解React中合并單元格的正確寫法

    用表格進行頁面布局,頁面布局在各種瀏覽器的的兼容性, 本文主要介紹了詳解React中合并單元格的正確寫法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01

最新評論