ReactJS动态更改背景图像?

时间:2015-01-15 15:08:20

标签: css reactjs react-jsx

我试图为以下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>
  )
}

感谢您的帮助

2 个答案:

答案 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