我试图为以下div动态更改背景图片样式:
这是我更改它的组件,
render: function() {
var divImage = {
backgroundImage : "url(" + this.state.song.imgSrc + "),url(" + this.state.nextImgSrc + ");"
};
return (
<li>
<div ref="image-pane" className="player" style={divImage}></div>
</li>
)
}
感谢您的帮助
答案 0 :(得分:26)
您还没有指定何时更改backgroundImage
,因此我创建了使用onClick
更改版本的版本:
React.createClass({
getInitialState: function () {
nextImg: false,
},
handleClick: function () {
this.setState({ nextImg: !this.state.nextImg })
},
render: function() {
var imgUrl = this.state.nextImg ? this.state.nextImgSrc : this.state.song.imgSrc;
var divStyle = {
backgroundImage: 'url(' + imgUrl + ')'
}
return (
<li>
<div ref="image-pane" style={divStyle} onClick={this.handleClick} className="player"></div>
</li>
)
}
});
请注意backgroundImage: 'url(' + imgUrl + ')'
不再必须有分号,实际上后面的分号会导致React引发错误。
答案 1 :(得分:2)
这是由您的样式中的尾随分号引起的。请参阅react issues #2862。