首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ReactJs在条件下改变类

ReactJs在条件下改变类
EN

Stack Overflow用户
提问于 2020-09-28 04:53:43
回答 3查看 71关注 0票数 0

我正在学习ReactJs,并提出了动态呈现类

代码语言:javascript
复制
 render() {
  let classes = "badge m-2 badge-";

  classes += this.state.count === 0 ? "warning" : "primary";

  
return (
  <div>
      
    <span  className={classes}>{this.formatCount()}</span>
    <button className="btn btn-secondary btn-sm">Increment</button>
  </div>
);

想知道+= this.state.count ===0类是如何实现的吗?“警告”:“初级”;有效

我的意思是x += y;应该是x=x+ y;为什么要用this.state.count添加类?

我在这里应用的逻辑是

this.state.count === 0 ? classes = "badge m-2 badge-warning" : classes = "badge m-2 badge-primary";

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-09-28 04:59:35

这是工作中的三元算子

这一逻辑相当于:

代码语言:javascript
复制
if(this.state.count === 0)
    classes += "warning";
    // classes = "badge m-2 badge-warning"
else
    classes += "primary";
    // classes = "badge m-2 badge-primary"
票数 0
EN

Stack Overflow用户

发布于 2020-09-28 05:07:26

试着这样做,我认为这会使代码变得清晰。

代码语言:javascript
复制
return (
<div>
     <span  className={`badge m-2 badge-${this.state.count === 0 ? "warning" : "primary"}`}>{this.formatCount()}</span>
    <button className="btn btn-secondary btn-sm">Increment</button>
  </div>
);
票数 0
EN

Stack Overflow用户

发布于 2020-09-28 05:14:57

看起来,您可能缺少一个设置状态的增量函数。看这一节:

代码语言:javascript
复制
classes += this.state.count === 0 ? "warning" : "primary";

您正在使用this.state.count接收状态,并使用三元运算符在“警告”和“”之间切换。在另一个文件中,可能有一个事件处理程序函数,它将确定事件触发时状态设置为什么。

三元算子首先工作,其结果是

代码语言:javascript
复制
this.state.count === 0 ? "warning" : "primary"; 

被添加到类中。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64096129

复制
相关文章

相似问题

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