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

您的位置:首頁技術(shù)文章
文章詳情頁

基于JS實現(xiàn)視頻上傳顯示進(jìn)度條

瀏覽:251日期:2024-05-08 18:47:51

示例代碼:

css部分:

#content{border: 1px solid saddlebrown;padding: 16px;border-radius: 2px} .list {top: 15px;width: 140px;height: 40px; border:1px solid #0082E6; display:inline-block;border-radius: 2px;position: relative; line-height: 40px;} #file{position: absolute;opacity: 0;color:white;width: 100%;height: 100%;z-index: 100;} .list span{ display: inline-block; text-align: center; width: 100%; line-height: 40px; position: absolute; color: #0082E6; } video{ margin-top: 8px; border-radius: 4px; } ._p{ margin: 14px; } ._p input{ display: inline-block; width: 70%; margin-left: 6px; } ._p span{ font-size: 15px; }

html部分

<div > <p class='_p'><span>視頻標(biāo)題</span>:<input type='text' placeholder='請輸入視頻名稱'></p> <p class='_p'> <span>選擇視頻: </span> <!--文件選擇按鈕--> <a href='javascript:;' rel='external nofollow' > <input type='file' name='myfile' onchange='UpladFile();' /><span>選擇視頻</span> </a> <!--上傳速度顯示--> <span id='time'></span> </p> <!--顯示消失--> <ul style='display: none;'> <li tabindex='0' > <a class='el-upload-list__item-name'> <i class='el-icon-document'></i><span id='videoName'>food.jpeg</span> </a> <label > <i ></i> </label> <i onclick='del();'></i> <i class='el-icon-close-tip'></i> </li> </ul> <!--進(jìn)度條--> <div style='display: none;'> <div class='el-progress-bar'> <div style='height: 6px;'><div style='width: 0%;'></div> </div> </div> <div style='font-size: 14.4px;'>0%</div> </div> <p class='_p'><span>上傳視頻</span>:<button type='button' onclick='sub();'>上傳</button></p> <!--預(yù)覽框--> <div class='preview'> </div> </div>

js部分:

<script type='text/javascript'> var xhr;//異步請求對象 var ot; //時間 var oloaded;//大小 //上傳文件方法 function UpladFile() { var fileObj = document.getElementById('file').files[0]; // js 獲取文件對象 if(fileObj.name){ $('.el-upload-list').css('display','block'); $('.el-upload-list li').css('border','1px solid #20a0ff'); $('#videoName').text(fileObj.name); }else{ alert('請選擇文件'); } } /*點(diǎn)擊取消*/ function del(){ $('#file').val(’’); $('.el-upload-list').css('display','none'); } /*點(diǎn)擊提交*/ function sub(){ var fileObj = document.getElementById('file').files[0]; // js 獲取文件對象 if(fileObj==undefined||fileObj==''){ alert('請選擇文件'); return false; }; var title = $.trim($('#title').val()); if(title==’’){ alert('請?zhí)顚懸曨l標(biāo)題'); return false; } var url = '{php echo webUrl(’goods/iframe.upload’)}'; // 接收上傳文件的后臺地址 var form = new FormData(); // FormData 對象 form.append('mf', fileObj); // 文件對象 form.append('title', title); // 標(biāo)題 xhr = new XMLHttpRequest(); // XMLHttpRequest 對象 xhr.open('post', url, true); //post方式,url為服務(wù)器請求地址,true 該參數(shù)規(guī)定請求是否異步處理。 xhr.onload = uploadComplete; //請求完成 xhr.onerror = uploadFailed; //請求失敗 xhr.upload.onprogress = progressFunction; //【上傳進(jìn)度調(diào)用方法實現(xiàn)】 xhr.upload.onloadstart = function() { //上傳開始執(zhí)行方法 ot = new Date().getTime(); //設(shè)置上傳開始時間 oloaded = 0; //設(shè)置上傳開始時,以上傳的文件大小為0 }; xhr.send(form); //開始上傳,發(fā)送form數(shù)據(jù) } //上傳進(jìn)度實現(xiàn)方法,上傳過程中會頻繁調(diào)用該方法 function progressFunction(evt) { // event.total是需要傳輸?shù)目傋止?jié),event.loaded是已經(jīng)傳輸?shù)淖止?jié)。如果event.lengthComputable不為真,則event.total等于0 if(evt.lengthComputable) { $('.el-progress--line').css('display','block'); /*進(jìn)度條顯示進(jìn)度*/ $('.el-progress-bar__inner').css('width', Math.round(evt.loaded / evt.total * 100) + '%'); $('.el-progress__text').html(Math.round(evt.loaded / evt.total * 100)+'%'); } var time = document.getElementById('time'); var nt = new Date().getTime(); //獲取當(dāng)前時間 var pertime = (nt - ot) / 1000; //計算出上次調(diào)用該方法時到現(xiàn)在的時間差,單位為s ot = new Date().getTime(); //重新賦值時間,用于下次計算 var perload = evt.loaded - oloaded; //計算該分段上傳的文件大小,單位b oloaded = evt.loaded; //重新賦值已上傳文件大小,用以下次計算 //上傳速度計算 var speed = perload / pertime; //單位b/s var bspeed = speed; var units = ’b/s’; //單位名稱 if(speed / 1024 > 1) { speed = speed / 1024; units = ’k/s’; } if(speed / 1024 > 1) { speed = speed / 1024; units = ’M/s’; } speed = speed.toFixed(1); //剩余時間 var resttime = ((evt.total - evt.loaded) / bspeed).toFixed(1); time.innerHTML = ’上傳速度:’ + speed + units + ’,剩余時間:’ + resttime + ’s’; if(bspeed == 0) time.innerHTML = ’上傳已取消’; } //上傳成功響應(yīng) function uploadComplete(evt) { //服務(wù)斷接收完文件返回的結(jié)果 注意返回的字符串要去掉雙引號 if(evt.target.responseText){ var str = '../shiping/'+evt.target.responseText; alert('上傳成功!'); $('.preview').append('<video controls=’’ autoplay=’’ name=’media’><source src='http://www.b3g6.com/bcjs/+str+' type=’video/mp4’></video>'); }else{ alert('上傳失敗'); } } //上傳失敗 function uploadFailed(evt) { alert('上傳失敗!'); }</script>

后臺用PHP實現(xiàn)

//視頻上傳 public function upload(){ global $_W; global $_GPC; $fileArr = $_FILES[’mf’]; $title = $_GPC[’title’]; /*var_dump($title); exit;*/ //設(shè)置預(yù)覽目錄,上傳成功的路徑 $previewPath = '../shiping/'; $ext = pathinfo($fileArr[’name’], PATHINFO_EXTENSION);//獲取當(dāng)前上傳文件擴(kuò)展名 $arrExt = array(’3gp’,’rmvb’,’flv’,’wmv’,’avi’,’mkv’,’mp4’,’mp3’,’wav’,);if(!in_array($ext,$arrExt)) { exit(json_encode(-1,JSON_UNESCAPED_UNICODE));//視/音頻或采用了不合適的擴(kuò)展名! } else { //文件上傳到預(yù)覽目錄 $previewName = ’pre_’.md5(mt_rand(1000,9999)).time().’.’.$ext; //文件重命名 $previewSrc = $previewPath.$previewName;if(move_uploaded_file($fileArr[’tmp_name’],$previewSrc)){//上傳文件操作,上傳失敗的操作 exit($previewName);} else { //上傳成功的失敗的操作 exit(json_encode(0,JSON_UNESCAPED_UNICODE));}} }

實現(xiàn)效果:

選擇視頻

基于JS實現(xiàn)視頻上傳顯示進(jìn)度條

上傳中........

基于JS實現(xiàn)視頻上傳顯示進(jìn)度條

上傳完成

基于JS實現(xiàn)視頻上傳顯示進(jìn)度條

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费人成在线不卡| 99久久九九| 美女视频黄久久| 婷婷中文字幕一区| 国产精品红桃| 国内激情久久| av资源中文在线| 福利一区和二区| 精品国产成人| 色综合五月天| 69精品国产久热在线观看| 国产视频一区三区| 欧美精品九九| 亚洲免费成人| 亚洲作爱视频| 国产精品99免费看| 久久久久国产精品一区三寸| 久久青青视频| 久久狠狠婷婷| 欧美va天堂在线| 伊人精品一区| 婷婷精品进入| 国产毛片久久| 在线观看亚洲精品福利片| 日韩国产在线观看一区| 欧美一区二区三区久久精品| 午夜久久99| 最近国产精品视频| 91精品一区| 精品在线网站观看| 成人羞羞视频播放网站| 国产日韩专区| 国产精品第十页| 日韩精品水蜜桃| 午夜在线精品偷拍| 高清精品久久| 国产日韩欧美在线播放不卡| 91视频精品| 在线国产一区二区| 日韩福利视频导航| 国产成人精品三级高清久久91| 免费一级欧美片在线观看网站| 国产精品自在| 婷婷六月综合| 亚洲午夜精品久久久久久app| 国产精品a级| 亚洲精品2区| 福利精品在线| 日韩av中文字幕一区二区三区| 婷婷五月色综合香五月| 国产视频一区二| 久久伊人亚洲| 狠狠久久伊人| 欧美影院视频| 一级成人国产| 日韩精品第一区| 日韩一区二区三免费高清在线观看| 国产成人精品一区二区三区在线| 免费中文字幕日韩欧美| 91精品婷婷色在线观看| 高清精品久久| 日韩激情啪啪| 亚洲伊人精品酒店| 性一交一乱一区二区洋洋av| 日韩欧美精品| 精品国产精品国产偷麻豆| 日韩精品三级| 青青国产91久久久久久| 91精品国产自产在线丝袜啪| 日韩精品亚洲一区二区三区免费| 亚洲精品日本| 91tv亚洲精品香蕉国产一区| 日韩在线二区| 欧美性www| 亚洲一级大片| 日本中文字幕一区二区| 成人精品视频| 国产精品久久亚洲不卡| 日本aⅴ精品一区二区三区 | 国产91久久精品一区二区| 国产不卡一区| 日韩88av| se01亚洲视频 | 日韩精品亚洲专区| 亚洲免费观看高清完整版在线观| 一区二区自拍| 午夜电影一区| 日韩毛片一区| 91成人在线| 国产精品资源| 捆绑调教美女网站视频一区| 精品一区二区三区中文字幕视频| 国产欧美日韩综合一区在线播放| 国产精品午夜av| 高清av一区| 好吊日精品视频| 欧美亚洲国产日韩| 天堂8中文在线最新版在线| 蜜臀久久99精品久久一区二区 | 免费久久99精品国产自在现线| 亚洲精品麻豆| 欧美国产专区| 不卡在线一区二区| 亚洲va久久久噜噜噜久久| 久久只有精品| 激情91久久| 日韩a一区二区| 日韩精品a在线观看91| 国产精品成人一区二区不卡| 日韩专区在线视频| 成人午夜网址| 国产精品一区高清| 亚洲制服欧美另类| 亚洲二区在线| 久久99蜜桃| 尤物tv在线精品| 超碰成人av| 石原莉奈一区二区三区在线观看| 国产极品模特精品一二| 亚洲激情久久| 亚洲欧美网站在线观看| 国产一区调教| 日韩精品1区2区3区| 亚洲www啪成人一区二区| 蜜桃久久久久久| 亚洲精品**中文毛片| 日韩av一区二区三区四区| 久久免费视频66| 首页亚洲欧美制服丝腿| 麻豆久久久久久| 亚洲专区欧美专区| 成人三级高清视频在线看| 国产欧美日韩亚洲一区二区三区| 婷婷成人在线| 国产精品国产一区| 男女男精品视频网| 亚洲www啪成人一区二区| 欧美日韩一区二区国产| 午夜电影亚洲| 色婷婷狠狠五月综合天色拍| 日韩精品一区二区三区中文在线| 不卡在线一区| 久久久夜夜夜| 久久影院资源站| 免费亚洲婷婷| 蜜桃精品视频| 欧美精品91| 不卡一区综合视频| 久久视频精品| 美女久久久久| 99精品综合| 亚洲国内精品| 伊人精品一区| 青青草91视频| 国产剧情一区二区在线观看| 亚洲乱码视频| 日韩av网站在线观看| 久久精品999| 欧美经典一区| 日韩电影免费网址| 亚洲网站视频| 成人精品视频| 99精品视频在线观看免费播放| 亚洲午夜久久久久久尤物| 日韩国产一区二区| 日韩三区在线| 99在线|亚洲一区二区| 中文字幕一区二区精品区| 亚洲免费专区| 国产精品红桃| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 国产精品tv| 久久久久久黄| 亚洲综合色婷婷在线观看| 欧美中文高清| 欧美激情另类| 亚洲激情国产| 日本91福利区| 国产精品xx| 免费视频一区二区| 中文一区一区三区免费在线观| 日本aⅴ精品一区二区三区| 精品视频99| 性色av一区二区怡红| 蜜桃久久久久| 欧美日韩精品免费观看视频完整| 亚洲精品美女| 97精品国产福利一区二区三区| 亚洲激情国产| 麻豆高清免费国产一区| 日韩免费福利视频| 亚洲精品大全| av日韩中文| 日韩精品视频一区二区三区| 日韩欧美二区| 国产精品男女| 红桃视频亚洲| 成人黄色av| 国产精品日韩欧美一区| 91日韩免费|