0

こんにちは私はjavascriptに非常に慣れていません。.webmと.mp4のビデオソースがありますが、JavaScriptで別のソースを追加するにはどうすればよいですか?1つ(webm)しか入れられませんでしたが、別のソースを追加するために必要なコードは何ですか?

前もって感謝します。

こんにちは、私がJSを入れる必要がある理由は、このスレッドのように、divxプラグインがhtml5ビデオ要素を置き換えているためです。divxWebプラグインがhtml5ビデオ要素を置き換えるのを防ぎますか?

これが私のコードです

<script type="text/javascript">
function changevid() {
    document.getElementById('vid').innerHTML = '<source src="http://avalonplay.com/video/loginvideo.webm" type="video/webm" />';
   document.getElementById('vid').load();
}
</script>

<body onload="changevid()">

   <video id="vid" width="800" height="450" loop="loop" preload="auto" autoplay style="width: 100%; height: auto; margin:0; right: 0;">    
   </video>

</body>
4

3 に答える 3

2

.appendChild()代わりに使用できます.innerHTML

しかし、より良い解決策は、ブラウザーのサポートをテストしてから、サポートされているビデオ タイプのみを追加することです。

window.onload = function(){

    var vid = document.getElementById('vid');
    var source = document.createElement('source');
    var supported = supportedVidType();

    source.src = 'http://avalonplay.com/video/loginvideo'+supported.src
    source.type = supported.type

    vid.appendChild( source );

}

var supportedVidType = function(){
    var vidTest = document.createElement( "video" )

    var types = {}

    if ( vidTest.canPlayType ) {
        // Check for MPEG-4 support
        types.mp4 = "" !== vidTest.canPlayType( 'video/mp4; codecs="mp4v.20.8"' )

        // Check for Webm support
        types.webm = "" !== vidTest.canPlayType( 'video/webm; codecs="vp8, vorbis"' );

        // Check for Ogg support
        types.ogg = "" !== vidTest.canPlayType( 'video/ogg; codecs="theora"' );
    }

    for( type in types ){
        if(types[type]) {
            return {
                type: 'video/'+type,
                src: '.'+type
            }
        } 
    }
}

ここに jsfiddle があります: http://jsfiddle.net/2gd3m/2/

于 2013-02-23T15:36:13.487 に答える
2

必要なものだけを追加することをお勧めします。

例えば:

function changevid() {
   var vid = document.getElementById('vid');

   if (vid.canPlayType('video/mp4') != '') {
      vid.src = 'http://avalonplay.com/video/loginvideo.mp4';
   }
   else if (vid.canPlayType('video/webm') != '') {
      vid.src = 'http://avalonplay.com/video/loginvideo.webm';
   }
   vid.load();
}
于 2013-02-23T15:47:15.353 に答える
0

video タグは複数のソースをサポートしています。

<video width="320" height="240" controls>
  <source src="movie.mp4" type="video/mp4">
  <source src="movie.ogg" type="video/ogg">
  Your browser does not support the video tag.
</video>

から: http://www.w3schools.com/tags/tag_video.asp

于 2013-02-23T15:38:51.163 に答える