Я пытаюсь создать пользовательский интерфейс, который позволяет пользователю загружать mp3-файлы со своего компьютера в плейлист. Прямо сейчас я получил название песни и часть слова, указывающего на правильную песню. Но теперь мне интересно, как проигрывать песню на аудиоэлементе каждый раз, когда пользователь нажимает кнопку li. Прямо сейчас это выглядит так:

enter image description here

И мое состояние выглядит так:

enter image description here

Вот мой код:

class DownloadTest extends React.Component {
  constructor(props) {
    super(props);

    this.handleClick = this.handleClick.bind(this);

    this.inputRef = React.createRef();

    this.state = {
      files: []
    };
  }



handleClick = event => {

  // Helper code to read file and return promise
  const readFile = (file) => {

    const fileList = [];

    const fileReader = new FileReader();

    // create the promise and return it
    return new Promise((resolve, reject) => {

      // if file reader has an error, report it
      fileReader.onerror = (error) => {
        reject({ error })
      }

      // if success, resolve the promise
      fileReader.onload = (e) => {
        resolve({
          name: file.name,
          link: e.target.result
        })
      }

      // start reading the file
      fileReader.readAsDataURL(file);

    })
  }

  // create all the file reader promises
  // create an array from the files list and use map to generate
  // an array of promises
  const allReaders = Array.from(event.target.files).map(readFile)

  // Now handle the array of promises we just created
  Promise.all(allReaders)
    .then(fileList => {
      console.log(fileList)
      // set the state that we have all the files
      this.setState({ files: fileList });
    })
    .catch(error => { 
       console.error(error)
    });

}

  render() {
     console.log(this.state);
    return (
      <div className="downloadMusic">
      <div className="input">
        <input
          onChange={this.handleClick}
          id="upload-file"
          className="inputName"
          type="file"
          multiple
          ref={this.inputRef}
        />
        </div>
        <div className="audio-player">
        <audio
         src="my_audio_file.ogg"
         autoPlay
         controls
         />
         </div>

        <div>
          <ul ref={this.ulRef}>
            {this.state.files.map((file, index) => (
              <li key={index}>
                <a href={file.link}>{file.name}</a>
              </li>
            ))}
          </ul>
        </div>
      </div>
    );
  }
}

export default DownloadTest;
1
DDavis25 17 Дек 2019 в 23:24

1 ответ

Обновленный ответ, проверено и работает. Вы можете использовать состояние компонента для изменения источника аудиоэлемента.

import React from "react";
import { render } from "react-dom";
import Joy from "./joy.wav"
import Alive from "./alive1.wav"

class App extends React.Component {
  constructor() {
    super();
    this.state = {
      audio: Joy
    }
  }

  render() {
    return (
      <div>
        <button onClick={() => this.setState({ audio: Alive })}>
          Change audio
        </button>
        <audio src={this.state.audio} controls />
      </div>
    )
  }
}
1
Kokodoko 18 Дек 2019 в 14:06