1. 程式人生 > 程式設計 >基於JS實現視訊上傳顯示進度條

基於JS實現視訊上傳顯示進度條

示例程式碼:

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 id="content" >
   <p class="_p"><span>視訊標題</span>:<input id="title" type="text" class="form-control" placeholder="請輸入視訊名稱"></p>
   <p class="_p">
     <span>選擇視訊: </span>
     <!--檔案選擇按鈕-->
    <a class="list" href="javascript:;" rel="external nofollow" > 
      <input id="file" type="file" name="myfile" onchange="UpladFile();" /><span>選擇視訊</span>
    </a> 
    <!--上傳速度顯示-->
    <span id="time"></span> 
   </p>
   <!--顯示消失-->
   <ul class="el-upload-list el-upload-list--text" style="display: none;">
     <li tabindex="0" class="el-upload-list__item is-success" >
       <a class="el-upload-list__item-name">
         <i class="el-icon-document"></i><span id="videoName">food.jpeg</span>
    </a> 
    <label class="el-upload-list__item-status-label" >
      <i class="el-icon-upload-success el-icon-circle-check" ></i>
    </label>
    <i class="el-icon-close" onclick="del();"></i>
    <i class="el-icon-close-tip"></i>
     </li>
   </ul>
  
  <!--進度條-->
  <div class="el-progress el-progress--line" style="display: none;">
    <div class="el-progress-bar">
      <div class="el-progress-bar__outer" style="height: 6px;">
        <div class="el-progress-bar__inner" style="width: 0%;">
        </div>
      </div>
    </div>
    <div class="el-progress__text" style="font-size: 14.4px;">0%</div>
  </div>
  <p class="_p"><span>上傳視訊</span>:<button class="btn btn-primary" 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("請填寫視訊標題");
      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 該引數規定請求是否非同步處理。
    xhr.onload = uploadComplete; //請求完成
    xhr.onerror = uploadFailed; //請求失敗
    xhr.upload.onprogress = progressFunction; //【上傳進度呼叫方法實現】
    xhr.upload.onloadstart = function() { //上傳開始執行方法
      ot = new Date().getTime(); //設定上傳開始時間
      oloaded = 0; //設定上傳開始時,以上傳的檔案大小為0
    };
    xhr.send(form); //開始上傳,傳送form資料
  }
  
  //上傳進度實現方法,上傳過程中會頻繁呼叫該方法
  function progressFunction(evt) { 
    // event.total是需要傳輸的總位元組,event.loaded是已經傳輸的位元組。如果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; //計算出上次呼叫該方法時到現在的時間差,單位為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="+str+" type='video/mp4'></video>");
    }else{
      alert("上傳失敗");
    }
  }
  //上傳失敗
  function uploadFailed(evt) {
    alert("上傳失敗!");
  }
</script>

後臺用PHP實現

//視訊上傳
  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));
        }    
    } 
  }

實現效果:

選擇視訊

基於JS實現視訊上傳顯示進度條

上傳中........

基於JS實現視訊上傳顯示進度條

上傳完成

基於JS實現視訊上傳顯示進度條

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。