首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在react中添加动态类?

如何在react中添加动态类?
EN

Stack Overflow用户
提问于 2021-12-24 10:08:16
回答 2查看 76关注 0票数 0

这里提到的宽度是内联的,所以我想做一个卡片组件,在那里宽度可以被动态地处理。我的意思是,将有一个卡片组件,可以通过jsx动态地处理宽度属性,假设一张卡的宽度是250 be,而对于另一张卡,宽度可能是100 be。

代码语言:javascript
复制
<div className="white-box v-align ht-100" style={{ width: '250px', marginRight: '10px' }}>
                        <div className="flex-one"></div>
                        <div className="wd-80">
                            <div className="fs-xl fw-bold" style={{ color: '#142654' }}>{pct}%</div>
                            <div className="small-text">{text}</div>
                        </div>
                        </div>
EN

回答 2

Stack Overflow用户

发布于 2021-12-24 10:23:03

解决这个问题的方法可能是使用道具:

代码语言:javascript
复制
// SomeComponent.js class
class SomeComponent {
    // Uncomment if you need to set a state
    //constructor(props) {
    //    super(props);
    //
    //    this.state = {};
    //}

    render() {
        let width = Math.min(Math.max(this.props.width, SOME_MAX_WIDTH), SOME_MIN_WIDTH); // clamp (optional)

        return ( // replace with your component
            <div style={{width: width, backgroundColor: "#23a4f6"}}>
                Width set from parent (and clamped)
            </div>
        );
    }
}
SomeComponent.defaultProps = {
    width: 200
};

// SomeComponent.js in functional
function SomeComponent({width}) {
    let width = Math.min(Math.max(this.props.width, SOME_MAX_WIDTH), SOME_MIN_WIDTH); // clamp (optional)

    return ( // replace with your component
        <div style={{width: width, backgroundColor: "#23a4f6"}}>
            Width set from parent (and clamped)
        </div>
    );
}
SomeComponent.defaultProps = {
    width: 200
};

// main.js
ReactDOM.render(<SomeComponent />, document.querySelector(".myelement"));
票数 0
EN

Stack Overflow用户

发布于 2021-12-24 10:18:51

您可以获取宽度变量(如let width = '100px' ),然后将此变量应用到代码中,如下所示。在这里,宽度可以作为支柱传递,它可以是任意值。

代码语言:javascript
复制
let width = '100px';
<div className="white-box v-align ht-100" style={{ width: width, marginRight: '10px' }}>
                        <div className="flex-one"></div>
                        <div className="wd-80">
                            <div className="fs-xl fw-bold" style={{ color: '#142654' }}>{pct}%</div>
                            <div className="small-text">{text}</div>
                        </div>
                        </div>
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70471755

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档