次の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>
)
}
助けてくれてありがとう
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が発生してエラーが発生します。
これは、スタイルの末尾のセミコロンが原因です。 react issues#2862 を参照してください。