HTML+JS實現視頻上傳顯示進度條

示例代碼:javascript

css部分:php

#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部分css

<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:;"> 
            <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部分:html

<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實現java

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

 

實現效果:web

選擇視頻json

上傳中........服務器

上傳完成app

相關文章
相關標籤/搜索