上傳文件進度條(筆記)

来源:https://www.cnblogs.com/dawenyang/archive/2018/12/03/10059076.html
-Advertisement-
Play Games

參考資料:CSDN-真實的上傳進度條 ...


參考資料:CSDN-真實的上傳進度條

<div class='form-group' style="display: none;" id="myModal_add_progressBar_Module">
    <label class='col-sm-2 control-label'>上傳進度:</label>
    <div class='col-sm-10'>
        <div class="progress">
            <div class="progress-bar" id="myModal_add_progressBar" role="progressbar" aria-valuemin="0" aria-valuemax="100" aria-valuenow="0" style="width:0;" >
            </div>
        </div>
        <span id="percentage"></span><span id="time"></span>
    </div>
</div>
        var ot;
        var oloaded;
        function save() {
            var form = new FormData();
            var file = document.querySelector('input[type=file]').files[0];
            form.append('logo', file); //angular 上傳的文件必須使用特殊的格式處理,不是json格式
            var xhr;
            xhr = new XMLHttpRequest();  // XMLHttpRequest 對象
            xhr.open("post", webConfig.apiRoot + "/api/ECategoryDetail/PostFiles", 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 uploadComplete(evt) {
            //服務斷接收完文件返回的結果
            var response = JSON.parse(evt.target.responseText);
            if (response.mark) //介面返回的數據標誌位,是否保存成功,保存成功則把文件相對地址更新到實體中
                $scope.editdata.SourceURL = response.result;
            $('#txtSourceURL').click();//手動觸發點擊事件,刷新文本框的值
        }
        //上傳失敗
        function uploadFailed(evt) {
            toaster.pop('error', "上傳失敗");
        }

        //上傳進度實現方法,上傳過程中會頻繁調用該方法
        function progressFunction(evt) {
            // event.total是需要傳輸的總位元組,event.loaded是已經傳輸的位元組。如果event.lengthComputable不為真,則event.total等於0
            if (evt.lengthComputable) {
                $("#myModal_add_progressBar").css("width", Math.round(evt.loaded / evt.total * 100) + "%");
                $("#myModal_add_progressBar").html(Math.round(evt.loaded / evt.total * 100) + "%");
                $("#percentage").html("已上傳" + Math.round(evt.loaded / evt.total * 100) + "%");
            }
            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").html(',速度:' + speed + units + ',剩餘時間:' + resttime + 's');
        }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、修改點擊的動畫 函數: 這是預設的點擊的動畫 我們用代碼修改一下: 這是之後的效果: 二、設置下劃線指示器的寬度不要填充完(動態的根據TabView的寬度來設置自身的寬度) 函數: 這是預設的效果 我們用代碼修改一下: 這是之後的效果: 三、設置下劃線指示器的樣式 函數: 這是預設的效果 我們用 ...
  • "覓知音"這個APP的第一個版本從提交審核到上架,歷時三個星期,其中遇到一些審核上的問題,它的處理或許能幫助到遇到同樣問題的小伙伴們,所以這裡列舉出來,這三個星期如何跟蘋果的審核團隊“鬥智鬥勇”。 ...
  • 力有不逮的對象 眾所周知,在 中,直接修改對象屬性的值無法觸發響應式。當你直接修改了對象屬性的值,你會發現,只有數據改了,但是頁面內容並沒有改變。 這是什麼原因? 原因在於: 的響應式系統是基於 這個方法的,該方法可以監聽對象中某個元素的獲取或修改,經過了該方法處理的數據,我們稱其為響應式數據。但是 ...
  • 聲明 本系列文章內容全部梳理自以下幾個來源: 《JavaScript權威指南》 "MDN web docs" "Github:smyhvae/web" "Github:goddyZhao/Translation/JavaScript" 作為一個前端小白,入門跟著這幾個來源學習,感謝作者的分享,在其基 ...
  • 方法一:footer高度固定+絕對定位 HTML代碼: CSS代碼: 實現的效果: 首先,設置body的高度至少充滿整個屏幕,並且body作為footer絕對定位的參考節點; 其次,設置main(footer前一個兄弟元素)的padding-bottom值大於等於footer的height值,以保證 ...
  • 學習Vue的一些總結,第一次寫博客,文筆實在是很差 不過我會不斷寫的。 這裡只寫了一部分常用的vue的指令,後面還會有的。 ...
  • 12.3事件對象 1.每個元素身上的事件都是天生自帶的,不需要我們去定義,只需要我們給這個事件綁定一個方法, 2.事件綁定的寫法 1.div.onclick=function(){} DOM 0級事件綁定 2.div.addEventListener()或div.attachEvent() DOM2 ...
  • 內置類型 JS 中分為七種內置類型,七種內置類型又分為兩大類型:基本類型和對象(Object)。 基本類型有六種: ,`undefined boolean number string symbol`。 其中 JS 的數字類型是浮點類型的,沒有整型。並且浮點類型基於 IEEE 754標準實現,在使用中 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...