【发布时间】:2016-04-03 23:19:33
【问题描述】:
我是 ReactJS 和 JSX 的新手,我对下面的代码有一点问题。
我正在尝试为每个li 的className 属性添加多个类:
<li key={index} className={activeClass, data.class, "main-class"}></li>
我的 React 组件是:
var AccountMainMenu = React.createClass({
getInitialState: function() {
return { focused: 0 };
},
clicked: function(index) {
this.setState({ focused: index });
},
render: function() {
var self = this;
var accountMenuData = [
{
name: "My Account",
icon: "icon-account"
},
{
name: "Messages",
icon: "icon-message"
},
{
name: "Settings",
icon: "icon-settings"
}
/*{
name:"Help & Support <span class='font-awesome icon-support'></span>(888) 664.6261",
listClass:"no-mobile last help-support last"
}*/
];
return (
<div className="acc-header-wrapper clearfix">
<ul className="acc-btns-container">
{accountMenuData.map(function(data, index) {
var activeClass = "";
if (self.state.focused == index) {
activeClass = "active";
}
return (
<li
key={index}
className={activeClass}
onClick={self.clicked.bind(self, index)}
>
<a href="#" className={data.icon}>
{data.name}
</a>
</li>
);
})}
</ul>
</div>
);
}
});
ReactDOM.render(<AccountMainMenu />, document.getElementById("app-container"));
【问题讨论】:
-
我在这里找到了一个简短的答案stackoverflow.com/a/36209517/4125588,只需使用 JavaScript 加入这个类,静态或动态,使用 '+' 运算符,记得在除第一个类之外的类之前插入'',如HTML中真正的类应该像'ab c',它们之间也是空格。
-
为什么
classNames={{foo: true, bar: true, baz: false}}和classNames={["foo", "bar"]}不只是工作? -
那你为什么只为 li 元素分配一个类名“active”?
-
可以查看npmjs.com/package/@ivanhanak_com/react-join-classnames,这里基本上可以使用
<div className={classes(isTrue && "willRenderThisClass")} />
标签: javascript css reactjs ecmascript-6