Создание аудио-сайта на React - ошибка парсинга

В настоящее время он дает мне ошибку синтаксического анализа в моих троичных операторах, от this.state.isHovered до конечного тега. Я знаю, что мне нужно заключить утверждения в фигурные скобки, но не знаю, где именно.

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

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

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

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();
 }
}

isHovered(song) {
 this.setState({isMouseEnter: song })
};


isNotHovered(song) {
 this.setState({isMouseLeave: null})
};



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)}
          onMouseEnter = {() => this.isHovered(song)}
            onMouseLeave = {() => this.isNotHovered(song)}>
    <td>
    {(this.state.isHovered === song) ? (<span className = "ion-md-play"></span>) :
     (this.state.isPlaying === true && this.state.currentSong === song) ? (<span className = "ion-md-pause"></span>) :
     (this.state.isPlaying !== true && this.state.currentSong === song) ? (<span className = "ion-md-play"></span>) }
    </td>
    <td key='number'   > {index + 1}  </td>
    <td key='title'    > {song.title} </td>
    <td key='duration' > {song.duration} </td>

    </tr>
  )}
  </tbody>
  </table>
  </section>
  );
 }
}

export default Album;

можешь еще добавить ошибку?

Pranay Tripathi 17.11.2018 21:54

Ваша последняя строка в троичной системе не содержит : (else)

Gabriele Petrioli 17.11.2018 21:56
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
2
36
1

Ответы 1

в вашем последнем тернарном условии отсутствует условие else. Используйте одно из следующего:

{(this.state.isHovered === song) ? (<span className = "ion-md-play"></span>) :
     (this.state.isPlaying === true && this.state.currentSong === song) ? (<span className = "ion-md-pause"></span>) :
     (this.state.isPlaying !== true && this.state.currentSong === song) ? (<span className = "ion-md-play"></span>) : null }

или

{(this.state.isHovered === song) ? (<span className = "ion-md-play"></span>) :
     (this.state.isPlaying === true && this.state.currentSong === song) ? (<span className = "ion-md-pause"></span>) :
     (this.state.isPlaying !== true && this.state.currentSong === song) && (<span className = "ion-md-play"></span>) }

Также лучше выделить такую ​​сложную логику в функцию компонента и вернуть подходящее значение. Это не будет соответствовать стандарту eslint или linting для JS.

Оцените вклад, и ваши решения сработали. Я не уверен, что вы имеете в виду, извлекая функцию из компонента и возвращая значение

cjl85 17.11.2018 22:56

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

cjl85 17.11.2018 22:56

Вы умеете загружать скриншоты? Я пытаюсь показать веб-страницу или ошибки

cjl85 17.11.2018 23:00

Другие вопросы по теме