日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript css3實現簡單視頻彈幕功能

瀏覽:426日期:2023-05-31 09:16:06

本文嘗試寫了一個demo模擬了最簡單的視頻彈幕功能。

思路:

設置一個<div>和所播放的video的大小一致,把這個div標簽蒙在video上面用于放置彈幕。在video的右邊放一個<ul>列表用于顯示彈幕列表。

屏幕上面的彈幕,把內容放在<span>標簽里面,一般一行字都是從左邊飛到右邊, 為了簡單起見,這個移動就用了CSS3 的transition 屬性。position設置為absolute,那么就用的transition過度left屬性,實現彈幕的移動。當然要注意設置其父元素的樣式 overflow:hidden; 這樣當字體飛出去的時候,就會隱藏飛出去的部分。

當點擊發送的時候,獲取input中的內容、當前日期、視頻播放的進度video.currentTime,把這個內容作為一個對象存入一個數組中。把放置彈幕的span標簽加入到div蒙版里,設置它的left,transition就會從當前left過度到下一個left,所以實現了移動。過渡完之后這個span標簽就沒用了,用removeChild把它中父元素中移除。同時把生成的<li>標簽加入到ul中。

代碼:

<!--Created by CC on 2017/10/11--> <!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><style type='text/css'> .mainBody{margin: 10px auto;text-align: center;font-family: arial;position:relative; } .send{ width:700px;margin:0px auto;text-align:left; } .my-msg{ width:85%; height:35px; } .my-btn{background-color: #ccd0d7;border-radius: 8px;width: 50px;height: 35px;margin-left:30px;border:1px solid #00a1d6; } .my-list{display:inline-block;vertical-align: top;border:1px solid #ccd0d7;width:200px;height:450px;overflow: auto; } .my-tm{position:absolute;top:0px;height:366px;width: 710px;overflow:hidden; } .rtol{position:absolute;display: inline-block;height:28px;overflow: hidden;font-size:24px;color:#fff;left:720px;-moz-transition:left 4s linear;-webkit-transition:left 4s linear;-o-transition:left 4s linear; } ul{text-align: left;list-style-type:none;margin-top:0px;padding-left: 8px; } li span {text-align: left;color: #99a2aa; }</style><body><div> <div class='mainBody'><div style='display:inline-block'><video src='https://rkxy.com.cn/big_buck_bunny.mp4' controls></video><div class='send'> <input type='text' placeholder='發送彈幕~'> <input type='button' value='發送'></div></div><div class='my-list'> <span style='color: #00a1d6'>~彈幕~</span> <hr /> <ul id='msg'> </ul></div><div id='tmbox'></div> </div></div><script> var tm=document.getElementById(’tmbox’); var btn=document.getElementById(’sendcc’); var video=document.getElementsByTagName(’video’)[0]; var list=document.getElementById(’msg’); var msg=document.getElementById(’msgcc’); var infor=[]; window.οnlοad=function() {//設置位置 tm.style.left=(document.body.offsetWidth-911)/2+’px’; } window.οnresize=function(){tm.style.left=(document.body.offsetWidth-911)/2+’px’; } //獲取當前日期 function getNowFormatDate() {var date = new Date();var seperator1 = '-';var seperator2 = ':';var month = date.getMonth() + 1;var strDate = date.getDate();if (month >= 1 && month <= 9) { month = '0' + month;}if (strDate >= 0 && strDate <= 9) { strDate = '0' + strDate;}var currentdate = month + seperator1 + strDate + ' ' + date.getHours() + seperator2 + date.getMinutes();return currentdate; } //按下發送鍵 btn.οnclick=function(){var value=msg.value;if(value&&value!=’’){ var itemInfor={}; itemInfor.value=value; itemInfor.showTime=video.currentTime; //時間 itemInfor.sendTime=getNowFormatDate(); //發送時間 //彈幕列表 var li=document.createElement(’li’); li.className=’my-li’; li.innerHTML='<span> > '+value+'</span>'; list.appendChild(li); //當前彈幕 var text=document.createElement(’span’); text.className=’rtol’; text.style.top=Math.floor( Math.random()*12 )*30+’px’; text.innerHTML=value; tm.appendChild(text); //左邊位置 setTimeout(function(){text.style.left=-value.length*25+’px’; },200); //之后把不顯示的span刪除 setTimeout(function(){ tm.removeChild(text) //防止已有彈幕和當前發送的顯示沖突,在這里加入到數組中 infor.push(itemInfor);},5000 )} } //顯示已有彈幕 setInterval(function(){ if(video.paused==false) { infor.forEach(function(item){ var currentTime=video.currentTime; if(item.showTime<video.currentTime&&item.showTime>=(video.currentTime-0.5)) { var text=document.createElement(’span’); text.className=’rtol’; text.style.top=Math.floor( Math.random()*12 )*30+’px’; text.innerHTML=item.value; tm.appendChild(text); //左邊位置 setTimeout(function(){ text.style.left=-(item.value.length*25)+’px’; },200); //之后把不顯示的span刪除 setTimeout(function(){ tm.removeChild(text); },5000 ) } }); } },500)</script> </body></html>

效果:

JavaScript css3實現簡單視頻彈幕功能

雖然這樣寫很簡單,但是有個很大的問題就是transition過渡left屬性不能暫停,所以自然這個transition動畫就只能等它執行完。或者說每個<span>標簽的移動都用interval定時器來完成移動。不過這樣寫就要復雜一些。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费成人网www| 超碰在线99| 免费精品一区| 日韩毛片一区| 亚洲精品欧洲| 啪啪亚洲精品| 欧美日韩伊人| 老牛国内精品亚洲成av人片| 国产伦精品一区二区三区视频| 日韩在线黄色| 精品资源在线| 日产精品一区二区| 久久久久国产一区二区| 亚洲不卡av不卡一区二区| 97精品国产一区二区三区| 国产日韩在线观看视频| 日本电影久久久| 国产66精品| 日韩欧美网址| 在线看片国产福利你懂的| 久久一区精品| 国产福利亚洲| 精品三级国产| а√天堂8资源在线| 福利一区二区免费视频| 久久久久久久欧美精品| 亚洲一区二区免费看| 久久久天天操| 在线国产一区| 一本综合精品| 欧美日韩夜夜| 久久精品资源| 国产一二在线播放| 鲁大师精品99久久久| 欧美国产极品| 日韩网站中文字幕| 欧美精品九九| 免费中文字幕日韩欧美| 日韩区一区二| 日韩精品亚洲一区二区三区免费| 你懂的国产精品| 91精品精品| 亚洲天堂av资源在线观看| 久久精品72免费观看| 国产成人久久精品一区二区三区| 91亚洲成人| 亚洲欧美日韩一区在线观看| 亚洲精品免费观看| 国产精品流白浆在线观看| 日韩天堂在线| 日本中文字幕视频一区| 国产精品久久久久久妇女| yellow在线观看网址| 日韩影院在线观看| 精品91福利视频| 丝瓜av网站精品一区二区| 久久精品一区| 免费一区二区视频| 97精品国产福利一区二区三区| 9国产精品视频| 国产一区调教| 亚洲开心激情| 激情亚洲影院在线观看| 蜜桃av一区| 日本а中文在线天堂| 日本aⅴ亚洲精品中文乱码| 欧美特黄一级大片| 欧美韩一区二区| 中文字幕亚洲精品乱码| 免费福利视频一区二区三区| 欧美一区精品| 伊人久久亚洲热| 中文av在线全新| 国产麻豆一区| 少妇精品久久久| 激情久久久久久久| 国内在线观看一区二区三区| 亚洲精品精选| 欧美成人精品三级网站| 开心激情综合| 久久99精品久久久野外观看| 亚洲欧美伊人| 精品资源在线| 国产一区久久| 成人精品视频| 91精品电影| 欧美日韩免费观看视频| 精品久久精品| 欧美在线亚洲综合一区| 日韩大片在线观看| 精品久久视频| 精品午夜久久| 久久69成人| 日韩手机在线| 日本不卡中文字幕| 国产免费久久| 日本精品在线播放| 免费毛片在线不卡| 日韩精品影视| 国产综合色产| 老鸭窝毛片一区二区三区| 99热免费精品| 蜜桃免费网站一区二区三区| 蜜桃传媒麻豆第一区在线观看| 欧美久久精品一级c片| 午夜免费一区| 亚洲精品免费观看| 国产调教精品| 国产精久久一区二区| 精品国产不卡一区二区| 国产精品99一区二区三区| 日韩精品dvd| 国产日韩综合| 国产日韩欧美一区二区三区在线观看 | 国产精品久久久网站| 麻豆精品一区二区综合av| 岛国av在线播放| 激情五月综合| 日韩激情一二三区| 久久精品欧洲| 性欧美69xoxoxoxo| 欧美网站在线| 日韩激情av在线| 精品国产18久久久久久二百| 激情偷拍久久| 欧美亚洲tv| 日韩高清不卡| 日本国产欧美| 日韩伦理一区| 国产欧美69| 国产色综合网| 国产一区福利| 伊人久久大香伊蕉在人线观看热v| 欧美精品不卡| 蜜桃久久久久久| 国产高清不卡| 午夜一区在线| 日韩亚洲一区在线| 97久久超碰| 模特精品在线| 婷婷国产精品| 欧美xxxx中国| 国产乱码精品| 亚洲女人av| 欧美中文一区二区| 国产91在线播放精品| 日本综合精品一区| 亚洲欧美日韩精品一区二区 | 免费日韩av片| аⅴ资源天堂资源库在线| 国产免费播放一区二区| 欧美在线观看视频一区| 久久人人精品| 日本免费一区二区三区四区| 精品久久久亚洲| 精品三级久久久| 新版的欧美在线视频| 四虎884aa成人精品最新| 免费看av不卡| 久久久噜噜噜| 亚洲一区欧美激情| 亚洲日本国产| 精品国产a一区二区三区v免费| 免费视频久久| 久久美女性网| 久久久久久久久久久妇女| 黄色在线观看www| 国产aa精品| а√天堂8资源在线| 亚洲一区网站| 香蕉久久精品| 日韩影院在线观看| 激情综合网址| 天堂成人国产精品一区| 亚洲制服欧美另类| 日韩高清成人在线| 啪啪国产精品| 午夜精品福利影院| 你懂的国产精品永久在线| 91精品国产91久久久久久黑人| 日韩中文字幕av电影| 蜜桃视频欧美| 美国三级日本三级久久99| 国产a亚洲精品| 精品国产亚洲一区二区三区在线| 亚洲人成高清| 在线观看亚洲精品福利片| 国产精品色在线网站| 日韩一区精品视频| 久久aⅴ国产紧身牛仔裤| 久久亚洲美女| 国产亚洲精aa在线看| 国产中文一区| 国产韩日影视精品| 风间由美中文字幕在线看视频国产欧美| 亚洲免费成人av在线| 精品黄色一级片| 欧美精品九九| 伊人国产精品| 久久午夜视频|