有没有办法在反应中以<audio>播放音乐?

Daw*_*n17 3 javascript audio reactjs

我正在创建一个简单的React应用,该应用需要播放具有给定URL的音乐。我尝试使用硬编码的音乐URL进行测试,并像使用<audio>HTML一样使用标签来播放音乐。

class Music extends React.Component {
  render() {

    return (
      <span>

        <audio src="URL">
  </span>

    )
  }
}
Run Code Online (Sandbox Code Playgroud)

但这不会编译。在React应用中播放音乐的最简单方法是什么?

Mar*_*vic 6

一种解决方案是HTML5 Audio。创建new Audio对象并使用自定义Play/ Pause按钮对其进行控制。

基本示例:

class Music extends React.Component {
    constructor(props) {
    super(props);
    this.state = {
      play: false,
      pause: true,
    }
    this.url = "http://streaming.tdiradio.com:8000/house.mp3";
    this.audio = new Audio(this.url);
  }

  play = () => {
  this.setState({ play: true, pause: false })
    this.audio.play();
  }
  
  pause = () => {
  this.setState({ play: false, pause: true })
    this.audio.pause();
  }
  
  render() {
    
  return (
    <div>
      <button onClick={this.play}>Play</button>
      <button onClick={this.pause}>Pause</button>
    </div>
    );
  }
}

ReactDOM.render(
  <Music />,
  document.getElementById('container')
);
Run Code Online (Sandbox Code Playgroud)
<div id="container"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

您也可以addEventListener用来控制和处理Play/ Pause

玩:

this.audio.addEventListener('play', () => {
  this.setState({
    play: true,
    pause: false,
  })
});
Run Code Online (Sandbox Code Playgroud)

暂停:

this.audio.addEventListener('pause', () => {
  this.setState({
    play: false,
    pause: true,
  })
});
Run Code Online (Sandbox Code Playgroud)

文档和示例:

音频/视频事件监听器

MDN HTML5音频

重要的提示:

HTML5 Audio元素没有stop()功能,因此pause()之后的音频仍在加载(在后台缓冲)。

这是一个解决方案: HTML5视频:强制中止缓冲

JSFIddle: https ://jsfiddle.net/y2j0vzbe/

希望这会有所帮助。