摘要:標(biāo)簽屬性當(dāng)然元素允許多個(gè)元素。元素可以鏈接不同的音頻文件。瀏覽器將使用第一個(gè)可識(shí)別的格式再如下面標(biāo)簽屬性下面先介紹下標(biāo)簽的一般用法標(biāo)簽的屬性如下注屬性供添加播放暫停和音量控件。
隨著互聯(lián)網(wǎng)的飛速發(fā)展以及HTML5的應(yīng)用,越來越多的項(xiàng)目中用到video,audio當(dāng)常用標(biāo)簽。
當(dāng)然audio元素允許多個(gè) source 元素。source 元素可以鏈接不同的音頻文件。瀏覽器將使用第一個(gè)可識(shí)別的格式:
再如下面:
下面先介紹下video標(biāo)簽的一般用法
video標(biāo)簽的屬性如下:
注:control 屬性供添加播放、暫停和音量控件。
一般用法:
當(dāng)然可以暫停,播放該視頻,使用方法如下:
function playPause() { var myVideo = document.getElementById("videoP"); if (myVideo.paused){ myVideo.play(); }else{ myVideo.pause(); } }
當(dāng)然video 元素允許多個(gè) source 元素。source 元素可以鏈接不同的視頻文件。瀏覽器將使用第一個(gè)可識(shí)別的格式:
如下:
獲取HTMLVideoElement和HTMLAudioElement對(duì)象
//audio可以直接通過new創(chuàng)建對(duì)象 Media = new Audio("http://www.abc.com/test.mp3"); //audio和video都可以通過標(biāo)簽獲取對(duì)象 Media = document.getElementById("media");Media方法和屬性
//錯(cuò)誤狀態(tài) Media.error; //null:正常 Media.error.code; //1.用戶終止 2.網(wǎng)絡(luò)錯(cuò)誤 3.解碼錯(cuò)誤 4.URL無效 //網(wǎng)絡(luò)狀態(tài) Media.currentSrc; //返回當(dāng)前資源的URL Media.src = value; //返回或設(shè)置當(dāng)前資源的URL Media.canPlayType(type); //是否能播放某種格式的資源 Media.networkState; //0.此元素未初始化 1.正常但沒有使用網(wǎng)絡(luò) 2.正在下載數(shù)據(jù) 3.沒有找到資源 Media.load(); //重新加載src指定的資源 Media.buffered; //返回已緩沖區(qū)域,TimeRanges Media.preload; //none:不預(yù)載 metadata:預(yù)載資源信息 auto: //準(zhǔn)備狀態(tài) Media.readyState; //1:HAVE_NOTHING 2:HAVE_METADATA 3.HAVE_CURRENT_DATA 4.HAVE_FUTURE_DATA 5.HAVE_ENOUGH_DATA Media.seeking; //是否正在seeking //回放狀態(tài) Media.currentTime = value; //當(dāng)前播放的位置,賦值可改變位置 Media.startTime; //一般為0,如果為流媒體或者不從0開始的資源,則不為0 Media.duration; //當(dāng)前資源長度 流返回?zé)o限 Media.paused; //是否暫停 Media.defaultPlaybackRate = value; //默認(rèn)的回放速度,可以設(shè)置 Media.playbackRate = value; //當(dāng)前播放速度,設(shè)置后馬上改變 Media.played; //返回已經(jīng)播放的區(qū)域,TimeRanges,關(guān)于此對(duì)象見下文 Media.seekable; //返回可以seek的區(qū)域 TimeRanges Media.ended; //是否結(jié)束 Media.autoPlay; //是否自動(dòng)播放 Media.loop; //是否循環(huán)播放 Media.play(); //播放 Media.pause(); //暫停 //控制 Media.controls; //是否有默認(rèn)控制條 Media.volume = value; //音量 Media.muted = value; //靜音 //TimeRanges(區(qū)域)對(duì)象 TimeRanges.length; //區(qū)域段數(shù) TimeRanges.start(index) //第index段區(qū)域的開始位置 TimeRanges.end(index) //第index段區(qū)域的結(jié)束位置事件
eventTester = function(e){ Media.addEventListener(e,function(){ console.log((new Date()).getTime(),e); }); } eventTester("loadstart"); //客戶端開始請(qǐng)求數(shù)據(jù) eventTester("progress"); //客戶端正在請(qǐng)求數(shù)據(jù) eventTester("suspend"); //延遲下載 eventTester("abort"); //客戶端主動(dòng)終止下載(不是因?yàn)殄e(cuò)誤引起), eventTester("error"); //請(qǐng)求數(shù)據(jù)時(shí)遇到錯(cuò)誤 eventTester("stalled"); //網(wǎng)速失速 eventTester("play"); //play()和autoplay開始播放時(shí)觸發(fā) eventTester("pause"); //pause()觸發(fā) eventTester("loadedmetadata"); //成功獲取資源長度 eventTester("loadeddata"); //提示當(dāng)前幀的數(shù)據(jù)是可用的 eventTester("waiting"); //等待數(shù)據(jù),并非錯(cuò)誤 eventTester("playing"); //開始回放 eventTester("canplay"); //可以播放,但中途可能因?yàn)榧虞d而暫停 eventTester("canplaythrough"); //可以播放,歌曲全部加載完畢 eventTester("seeking"); //尋找中 eventTester("seeked"); //尋找完畢 eventTester("timeupdate"); //播放時(shí)間改變 eventTester("ended"); //播放結(jié)束 eventTester("ratechange"); //播放速率改變 eventTester("durationchange"); //資源長度改變 eventTester("volumechange"); //音量改變
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/11020.html
摘要:尤其是喬布斯在年發(fā)布的一篇的文章。喬布斯在里面寫下了關(guān)于的一點(diǎn)看法,說明自己為什么不使用,談到關(guān)于的一些問題,比如開放性,安全性,對(duì)于設(shè)備續(xù)航的影響,不利于觸摸屏,等等。終于,于年月日,爸爸也放棄治療了,宣布將于年正式退休。 今天為大家分享一下html5中的視頻(video)與音頻(audio)。在進(jìn)入主題之前我們先了解一下Flash與html5這兩種技術(shù)的時(shí)代背景與發(fā)展歷史。 1.前...
摘要:尤其是喬布斯在年發(fā)布的一篇的文章。喬布斯在里面寫下了關(guān)于的一點(diǎn)看法,說明自己為什么不使用,談到關(guān)于的一些問題,比如開放性,安全性,對(duì)于設(shè)備續(xù)航的影響,不利于觸摸屏,等等。終于,于年月日,爸爸也放棄治療了,宣布將于年正式退休。 今天為大家分享一下html5中的視頻(video)與音頻(audio)。在進(jìn)入主題之前我們先了解一下Flash與html5這兩種技術(shù)的時(shí)代背景與發(fā)展歷史。 1.前...
閱讀 1331·2021-09-01 10:30
閱讀 2259·2021-07-23 10:38
閱讀 964·2019-08-29 15:06
閱讀 3211·2019-08-29 13:53
閱讀 3323·2019-08-26 11:54
閱讀 1896·2019-08-26 11:38
閱讀 2435·2019-08-26 10:29
閱讀 3187·2019-08-23 18:15