电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:149日期: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>視頻標題</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> <!--進度條--> <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> <!--預覽框--> <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('請選擇文件'); } } /*點擊取消*/ function del(){ $('#file').val(’’); $('.el-upload-list').css('display','none'); } /*點擊提交*/ 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標題'); return false; } var url = '{php echo webUrl(’goods/iframe.upload’)}'; // 接收上傳文件的后臺地址 var form = new FormData(); // FormData 對象 form.append('mf', fileObj); // 文件對象 form.append('title', title); // 標題 xhr = new XMLHttpRequest(); // XMLHttpRequest 對象 xhr.open('post', url, true); //post方式,url為服務器請求地址,true 該參數(shù)規(guī)定請求是否異步處理。 xhr.onload = uploadComplete; //請求完成 xhr.onerror = uploadFailed; //請求失敗 xhr.upload.onprogress = progressFunction; //【上傳進度調用方法實現(xiàn)】 xhr.upload.onloadstart = function() { //上傳開始執(zhí)行方法 ot = new Date().getTime(); //設置上傳開始時間 oloaded = 0; //設置上傳開始時,以上傳的文件大小為0 }; xhr.send(form); //開始上傳,發(fā)送form數(shù)據(jù) } //上傳進度實現(xiàn)方法,上傳過程中會頻繁調用該方法 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'); /*進度條顯示進度*/ $('.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(); //獲取當前時間 var pertime = (nt - ot) / 1000; //計算出上次調用該方法時到現(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 = ’上傳已取消’; } //上傳成功響應 function uploadComplete(evt) { //服務斷接收完文件返回的結果 注意返回的字符串要去掉雙引號 if(evt.target.responseText){ var str = '../shiping/'+evt.target.responseText; alert('上傳成功!'); $('.preview').append('<video controls=’’ autoplay=’’ name=’media’><source src='http://www.hdgsjgj.cn/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;*/ //設置預覽目錄,上傳成功的路徑 $previewPath = '../shiping/'; $ext = pathinfo($fileArr[’name’], PATHINFO_EXTENSION);//獲取當前上傳文件擴展名 $arrExt = array(’3gp’,’rmvb’,’flv’,’wmv’,’avi’,’mkv’,’mp4’,’mp3’,’wav’,);if(!in_array($ext,$arrExt)) { exit(json_encode(-1,JSON_UNESCAPED_UNICODE));//視/音頻或采用了不合適的擴展名! } else { //文件上傳到預覽目錄 $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)視頻上傳顯示進度條

上傳中........

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

上傳完成

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 贵州自考_贵州自学考试网| 北京工业设计公司-产品外观设计-产品设计公司-千策良品工业设计 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 深圳昂为官网-气体分析仪,沼气分析仪,动态配气仪,气体传感器厂家 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | EPDM密封胶条-EPDM密封垫片-EPDM生产厂家 | 并离网逆变器_高频UPS电源定制_户用储能光伏逆变器厂家-深圳市索克新能源 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 蒸汽吸附分析仪-进口水分活度仪|康宝百科 | 仿真植物|仿真树|仿真花|假树|植物墙 - 广州天昆仿真植物有限公司 | 烟台条码打印机_烟台条码扫描器_烟台碳带_烟台数据采集终端_烟台斑马打印机-金鹏电子-金鹏电子 | 申江储气罐厂家,储气罐批发价格,储气罐规格-上海申江压力容器有限公司(厂) | 上海阳光泵业制造有限公司 -【官方网站】 | 酒精检测棒,数显温湿度计,酒安酒精测试仪,酒精检测仪,呼气式酒精检测仪-郑州欧诺仪器有限公司 | 亚克力制品定制,上海嘉定有机玻璃加工制作生产厂家—官网 | 高低温老化试验机-步入式/低温恒温恒湿试验机-百科 | 潍坊大集网-潍坊信息港-潍坊信息网| 电磁流量计厂家_涡街流量计厂家_热式气体流量计-青天伟业仪器仪表有限公司 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 制冷采购电子商务平台——制冷大市场 | MTK核心板|MTK开发板|MTK模块|4G核心板|4G模块|5G核心板|5G模块|安卓核心板|安卓模块|高通核心板-深圳市新移科技有限公司 | 实木家具_实木家具定制_全屋定制_美式家具_圣蒂斯堡官网 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 【中联邦】增稠剂_增稠粉_水性增稠剂_涂料增稠剂_工业增稠剂生产厂家 | 洗瓶机厂家-酒瓶玻璃瓶冲瓶机-瓶子烘干机-封口旋盖压盖打塞机_青州惠联灌装机械 | 搜木网 - 木业全产业链交易平台,免费搜货、低价买货! | 软文世界-软文推广-软文营销-新闻稿发布-一站式软文自助发稿平台 | 方源木业官网-四川木门-全国木门专业品牌 | 分轨 | 上传文件,即刻分离人声和伴奏 | 温湿度记录纸_圆盘_横河记录纸|霍尼韦尔记录仪-广州汤米斯机电设备有限公司 | 北京网络营销推广_百度SEO搜索引擎优化公司_网站排名优化_谷歌SEO - 北京卓立海创信息技术有限公司 | 大巴租车平台承接包车,通勤班车,巴士租赁业务 - 鸿鸣巴士 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 深圳宣传片制作-企业宣传视频制作-产品视频拍摄-产品动画制作-短视频拍摄制作公司 | 商秀—企业短视频代运营_抖音企业号托管 | 车间除尘设备,VOCs废气处理,工业涂装流水线,伸缩式喷漆房,自动喷砂房,沸石转轮浓缩吸附,机器人喷粉线-山东创杰智慧 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 包塑软管|金属软管|包塑金属软管-闵彬管业 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 工程管道/塑料管材/pvc排水管/ppr给水管/pe双壁波纹管等品牌管材批发厂家-河南洁尔康建材 |