国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > AJAX > 正文

Ajax上傳文件進度條Codular

2024-09-01 08:27:16
字體:
來源:轉載
供稿:網友

現在,人們喜歡在瀏覽網頁時做一些其他事情而不離開該網頁,這通常是通過ajax來實現.大多數情況,人們使用jQuery來實現,但是隨著瀏覽器的進步,人們比不需要這么做.這里我們將介紹如何在不離開頁面的情況下將文件上傳到服務器,我們將使用與我們之前的文章中使用的相同的后端PHP代碼. 該腳本將上傳文件至服務器,同時顯示上傳進度,并最終返回上傳文件的鏈接地址.在某些情況下,你可能想要返回上傳文件的id或者其他的應用信息. Note: 該代碼不支持較老的ie瀏覽器,通過Can I use我們只支持ie10+

Let's Code

我們將從HTML結構開始,然后是JavaScript,然后我將給您提供PHP代碼,這部分改編于之前教程 - 對PHP代碼將不會有太多的解釋。

HTML

我們只需要使用兩個輸入框,一個是文件類型file,另一個只是一個按鈕button,以便我們可以監聽到它被點擊發送文件上傳請求。 我們還將有一個div,我們改變寬度以突出顯示上傳的狀態。

如下所示:

<!doctype html><html><head>  <meta charset="utf-8">  <title>JS File Upload with Progress</title>  <style>  .container {    width: 500px;    margin: 0 auto;  }  .progress_outer {    border: 1px solid #000;  }  .progress {    width: 20%;    background: #DEDEDE;    height: 20px;   }  </style></head><body>  <div class='container'>    <p>      Select File: <input type='file' id='_file'> <input type='button' id='_submit' value='Upload!'>    </p>    <div class='progress_outer'>      <div id='_progress' class='progress'></div>    </div>  </div>  <script src='upload.js'></script></body></html>

你將看到我們寫了一點進度條樣式,并在底部加入腳本文件來處理文件上傳以及進度條展示.

JavaScript

首先, 我們需要拿到我們將要使用的標簽,他們已經用id標記上.

var _submit = document.getElementById('_submit'), _file = document.getElementById('_file'), _progress = document.getElementById('_progress');

下一步,給_submit添加點擊事件,用以上傳我們選擇的文件.為此,我們將使用addEventListener方法,點擊按鈕后讓其調用upload方法.

_submit.addEventListener('click', upload);

現在我們可以繼續處理上傳,有以下幾步:

    檢查被選中的文件 動態創建要發送的文件數據 通過js創建XMLHttpRequest 上傳文件

檢查被選中的文件

我們的文件輸入框_file有一個查詢被選中文件隊列的參數files-如果你設置了multiple參數將可以選多個文件.我們做簡單的檢查判斷,如果該數組長度大于0,則繼續,否則直接返回.

if(_file.files.length === 0){  return;}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿城市| 星子县| 白山市| 陆丰市| 育儿| 凤山县| 余干县| 浦江县| 江陵县| 宝兴县| 普格县| 江达县| 云南省| 稻城县| 洪雅县| 湖南省| 三门县| 道真| 郓城县| 新干县| 怀安县| 黑河市| 敦煌市| 鲁山县| 台山市| 双峰县| 喀喇沁旗| 措美县| 蒙自县| 西林县| 疏附县| 昭通市| 陆川县| 丰台区| 锦州市| 石渠县| 东丽区| 金堂县| 道真| 龙里县| 犍为县|