Идентификатор начинается сразу после числовой литера - PullRequest
1 голос
/ 12 февраля 2012

Я показываю пару видео на своем веб-сайте и генерирую код после того, какой YoutubeID есть у видео. До сих пор он работал без проблем, но с идентификатором 6BD2qnBozvE мой сценарий работать не будет.

Мой код

function onYouTubePlayerReady(playerId) {

    e3fqE01YYWs = document.getElementById('e3fqE01YYWs');
      setTimeout(function(){
        e3fqE01YYWs.setVolume(100);
        e3fqE01YYWs.playVideo();
      }, 750);

    6BD2qnBozvE = document.getElementById('6BD2qnBozvE');
      setTimeout(function(){
        6BD2qnBozvE.setVolume(53);
        6BD2qnBozvE.playVideo();
      }, 750);
        }

Сообщение об ошибке в Firebug

идентификатор начинается сразу после числового литерала [Break On This Ошибка]

6BD2qnBozvE = document.getElementById ('6BD2qnBozvE');

Почему это происходит и как я могу это исправить?

Редактировать: Джереми Бэнкс объясняет почему, но я до сих пор не знаю, как решить мою проблему.

Вот как я генерирую свой код Javascript:

function onYouTubePlayerReady(playerId) {
<?php
foreach($projectMusicUn as $music => $volume){
?> 
<?php echo $music; ?> = document.getElementById('<?php echo $music; ?>');
setTimeout(function(){
    <?php echo $music; ?>.setVolume(<?php echo $volume; ?>);
<?php echo $music; ?>.playVideo();
  }, 750);
<?php
} //End of foreach($projectMusic as $music)
?>
}

1 Ответ

3 голосов
/ 12 февраля 2012

Вы пытаетесь присвоить переменную с именем 6BD2qnBozvE. Это не разрешено; имена переменных (идентификаторы) в JavaScript должны начинаться с буквы, подчеркивания или $.

Просто переименуйте его в что-то вроде video_6BD2qnBozvE. Пока вы это делаете, вам, вероятно, следует добавить ключевое слово var перед определением, чтобы не создавать глобальную переменную.

    var video_6BD2qnBozvE = document.getElementById('6BD2qnBozvE');

Добавляйте префикс, такой как video_ каждый раз, когда он используется в качестве переменной в вашем исходном коде:

function onYouTubePlayerReady(playerId) {
    <?php
    foreach($projectMusicUn as $music => $volume){
        ?> 
        var video_<?php echo $music; ?> = document.getElementById('<?php echo $music; ?>');
        setTimeout(function(){
            video_<?php echo $music; ?>.setVolume(<?php echo $volume; ?>);
            video_<?php echo $music; ?>.playVideo();
        }, 750);
        <?php
    } //End of foreach($projectMusic as $music)
    ?>
}
...