Добавление событий onMouseEnter и onMouseLeave в музыкальный проигрыватель - PullRequest
0 голосов
/ 21 февраля 2019

Я пишу приложение, в котором есть музыкальный проигрыватель, и я попал в блок.Я пытаюсь создать метод, который:

• При наведении курсора на песню вместо ее номера отображается кнопка «play».

• Отображается воспроизводимая в данный момент песня.кнопка «пауза» вместо номера песни.

• Приостановленная песня отображает кнопку «воспроизведения» вместо номера песни.

Я хочу использовать события onMouseEnter и onMouseLeave внутриэтот метод, но я не знаю с чего начать

вот мой компонент альбома

import React, { Component } from 'react';
import albumData from './../data/albums';

class Album extends Component {
    constructor(props) {
          super(props);

        const album = albumData.find( album => {
          return album.slug === this.props.match.params.slug
        });

        this.state = {
          album: album,
            currentSong: album.songs[0],
            isPlaying: false
        };

        this.audioElement = document.createElement('audio');
        this.audioElement.src = album.songs[0].audioSrc;
        }

        play() {
              this.audioElement.play();
              this.setState({ isPlaying: true });
            }

        pause() {
              this.audioElement.pause();
              this.setState({ isPlaying: false });
            }   

        setSong(song) {
              this.audioElement.src = song.audioSrc;
              this.setState({ currentSong: song });
            }

        handleSongClick(song) {
              const isSameSong = this.state.currentSong === song;
              if (this.state.isPlaying && isSameSong) {
                   this.pause();
                 } else {
                   if (!isSameSong) { this.setSong(song); }     
                   this.play();
                 }  
            }



    render() {
      return (
         <section className="album">
            <section id="album-info">
                 <img id="album-cover-art" src={this.state.album.albumCover} alt={this.state.album.title}/>
                 <div className="album-details">
                 <h1 id="album-title">{this.state.album.title}</h1>
                 <h2 className="artist">{this.state.album.artist}</h2>
                 <div id="release-info">{this.state.album.releaseInfo}</div>
              </div>
            </section>
            <table id="song-list">
                <colgroup>
                    <col id="song-number-column" />
                    <col id="song-title-column" />
                    <col id="song-duration-column" />
                </colgroup>  
                <tbody>
                {this.state.album.songs.map( (song, index) =>
                    <tr className="song" key={index} onClick={() => this.handleSongClick(song)} >
                          <td className="song-actions">
                             <button>
                                <span className="song-number">{index+1}</span>
                                <span className="ion-play"></span>
                                <span className="ion-pause"></span>
                            </button>
                          </td>
                          <td className="song-title">{song.title}</td>
                          <td className="song-duration">{song.duration}</td>
                    </tr>
                  )}
                </tbody>
            </table>
         </section>
      );
    }
 }


export default Album;

1 Ответ

0 голосов
/ 21 февраля 2019

В моем тесте с вашим кодом я добавил свойство showPlayOnHover , чтобы установить его как ложное, для обработки кнопки, появляющейся при наведении.

Добавлен метод визуализации или нет кнопки:

handlePlayOnHover = (song) => {
    this.setState({
        showPlayOnHover: !this.state.showPlayOnHover,
        isPlaying: !this.state.isPlaying
    })
    this.handleSongClick(song)
}

И структура рендеринга песни была обновлена ​​до:

<tr 
    className="song" key={index} 
    onClick={() => this.handleSongClick(song)}
    onMouseOver={() => this.handleOnHover(song)}
    onMouseOut={() => this.handleOnHover(song)}
>
      <td className="song-actions">
         <button>
            <span className="song-number">
                {!this.state.showPlayOnHover ? index+1 : <span className="ion-play"></span>}
            </span>
            <span className="ion-play"></span>
            <span className="ion-pause"></span>
        </button>
      </td>
      <td className="song-title">{song.title}</td>
      <td className="song-duration">{song.duration}</td>
</tr>

Метод handleOnHover обеспечивает условное отображение кнопки воспроизведения при наведении курсора иномер песни при наведении.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...