5

我的页面包含这个<video>带有几个 subtitle<track>的标签。我想通过使用jquery单击相应的国旗来动态启用轨道:

  <div id="lang">
    <img src="mini/ita.png" class="it" alt="Italiano" title="Italiano" />
    <img src="mini/eng.png" class="en" alt="English"  title="English"  />        
  </div>


<video controls="controls" >

  <source src="webcast.webm" />
  <source src="webcast.mp4"  />
  <source src="webcast.ogv"  />

  <track kind="subtitles" src="./sub-en.vtt" srclang="en" />
  <track kind="subtitles" src="./sub-it.vtt" srclang="it" />

</video>

<script>
$('#lang img').click(function(){
    language=$(this).attr('class');

    $('video track').removeAttr('default');
    $('video track[srclang='+language+']').attr('default','default');
});
</script>

“默认”属性已正确插入,但没有显示字幕。手动插入默认属性效果很好(在 chrome 和 opera 上)。

4

2 回答 2

1
<script>
$('#lang img').click(function(){
    var language=$(this).attr('class');

    $($('video').prop('textTracks')).prop('mode', function(){
        return this.language == language ? 'showing' : 'disabled';
    });
});
</script>
于 2012-11-29T08:13:41.713 回答
0
$('#lang img').click(function(){
    language=your value;
    $('#yourID').attr('srclang', language); 
 });

这样做..

于 2012-11-21T14:10:29.750 回答