JavaScript實現(xiàn)異步圖像上傳功能
當(dāng)向服務(wù)器上傳圖像時,根據(jù)服務(wù)器操作的復(fù)雜性和服務(wù)器性能,需要幾秒鐘到幾分鐘的時間來完成。本文的重點是在圖像上傳至服務(wù)器時使用JavaScript立即顯示圖像。
介紹
當(dāng)使用JavaScript將圖像上傳到服務(wù)器時,根據(jù)服務(wù)器操作的復(fù)雜性,可能需要幾秒到幾分鐘來完成操作。在某些情況下,即使圖像上傳成功,也需要花費更多的時間,這取決于服務(wù)器對圖像進(jìn)行額外處理的能力。
本文展示了一種使用代碼示例立即顯示圖像的方法(使用圖像的Base64編碼版本),同時將其上載到服務(wù)器,而無需等待操作完成。這種方法的目的是提高web應(yīng)用程序的用戶體驗,而不等待服務(wù)器做整個圖像的處理(例如,縮略圖生成、應(yīng)用過濾器等)后,上傳成功,因為它可以在客戶端web應(yīng)用程序上展示圖片。
背景
在使用AWS S3作為圖像存儲時,最初遇到了這個問題。圖像縮略圖的設(shè)置是使用AWS Lambda完成的,在使用web應(yīng)用程序的JavaScript成功上傳圖像到S3之后,S3將異步觸發(fā)AWS Lambda函數(shù),該函數(shù)將生成圖像的縮略圖并將其存儲在另一個S3中。盡管這是一個高度可伸縮和可靠的圖像縮略圖生成解決方案,但是web應(yīng)用程序要等到生成縮略圖才能在應(yīng)用程序的視圖中顯示它,這是不現(xiàn)實的。
使用的代碼
此代碼使用VanillaJS編寫,不使用任何第三方JavaScript庫,因此如果您使用任何第三方框架,您可以使用框架或庫提供的構(gòu)造來調(diào)整概念并實現(xiàn)它。
步驟1:將圖像加載到瀏覽器
如圖所示在上面的例子中,有兩個HTML元素的例子。< img > DOM元素有顯示選中的圖像。<input> DOM元素為用戶選擇圖像文件。使用JavaScript文件API,可以聽改變事件處理程序和加載圖像訪問使用JavaScript。
步驟2:生成Base64縮略圖
使用JavaScript訪問圖像后,將其加載到HTML5 FileReader并轉(zhuǎn)換為Base64數(shù)據(jù)URL。然后使用Base64數(shù)據(jù)URL更新 DOM元素。
步驟3:使用Ajax上傳文件
使用Ajax,圖像上傳被啟動到服務(wù)器。使用JavaScript, HTML表單提交將異步觸發(fā),具體的代碼將根據(jù)服務(wù)器實現(xiàn)而異,特別是在HTTP方法(例如,這里是POST)和URL方面。
如果服務(wù)器響應(yīng)包含圖像URL,則可以使用它相應(yīng)地更新 DOM元素,或者如果服務(wù)器維護(hù)了適當(dāng)?shù)膱D像訪問路徑約定(例如,/images/),則可以使用它加載圖像。
步驟4:(可選)客戶端縮略圖生成
<!DOCTYPE html> <html> <body> <input type="file" id="imageFileInput" accept=".jpg, .jpeg, .png" /> <img src="http://:0" id="preview" /> <script> document.getElementById('imageFileInput').addEventListener('change', function() { var img = this.files[0]; uploadImage(img, '/image/upload', function(url) { // Image upload to server response // Show the image using setImageUrl(URL) }); getBase64ImageUrl(img, function(base64ImageUrl) { var height = 100, width = 100; getThumbnail(base64ImageUrl, height, width, function(base64ThumbnailUrl) { setImageUrl(base64ThumbnailUrl); }) }); }, false); function setImageUrl(url) { document.getElementById('preview').setAttribute('src', url); }; function uploadImage(img, url, callback) { var xhr = new XMLHttpRequest(); var fd = new FormData(); xhr.open("POST", url, true); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { callback && callback(xhr.responseText); } }; fd.append("upload_image", img); xhr.send(fd); }; function getBase64ImageUrl(img, callback) { var reader = new FileReader(); reader.readAsDataURL(img); reader.onload = function() { callback && callback(reader.result); }; reader.onerror = function(error) { console.log('Error: ', error); }; }; function getThumbnail(base64ImageUrl, height, width, callback) { var canvas = document.createElement('canvas'); var ctx = canvas.getContext("2d"); var image = new Image(); image.src = base64ImageUrl; image.onload = function() { ctx.drawImage(image, 0, 0, width, height); callback && callback(canvas.toDataURL()); }; } </script> </body> </html>
總結(jié)
以上所述是小編給大家介紹的JavaScript實現(xiàn)異步圖像上傳功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 原生JS實現(xiàn)前端本地文件上傳
- JS實現(xiàn)可視化文件上傳
- js實現(xiàn)文件上傳功能 后臺使用MultipartFile
- JS+Struts2多文件上傳實例詳解
- vue.js 圖片上傳并預(yù)覽及圖片更換功能的實現(xiàn)代碼
- php+croppic.js實現(xiàn)剪切上傳圖片功能
- JavaScript使用享元模式實現(xiàn)文件上傳優(yōu)化操作示例
- JS實現(xiàn)圖片上傳多次上傳同一張不生效的處理方法
- js實現(xiàn)圖片上傳并預(yù)覽功能
- vue.js圖片轉(zhuǎn)Base64上傳圖片并預(yù)覽的實現(xiàn)方法
- Angularjs實現(xiàn)多圖片上傳預(yù)覽功能
- SpringBoot+Vue.js實現(xiàn)前后端分離的文件上傳功能
- node.js自動上傳ftp的腳本分享
- JS實現(xiàn)的文件拖拽上傳功能示例
- Vue2.0實現(xiàn)調(diào)用攝像頭進(jìn)行拍照功能 exif.js實現(xiàn)圖片上傳功能
- JS和Canvas實現(xiàn)圖片的預(yù)覽壓縮和上傳功能
- JavaScript代碼實現(xiàn)txt文件的上傳預(yù)覽功能
- js 實現(xiàn) input type="file" 文件上傳示例代碼
- js實現(xiàn)上傳圖片預(yù)覽的方法
- Servlet+Jsp實現(xiàn)圖片或文件的上傳功能具體思路及代碼
- 上傳圖片預(yù)覽JS腳本 Input file圖片預(yù)覽的實現(xiàn)示例
- JS實現(xiàn)上傳圖片的三種方法并實現(xiàn)預(yù)覽圖片功能
- js實現(xiàn)圖片上傳并正常顯示
- 一個簡單的jQuery插件ajaxfileupload.js實現(xiàn)ajax上傳文件例子
- JS中使用FormData上傳文件、圖片的方法
- 客戶端js判斷文件類型和文件大小即限制上傳大小
- js獲取上傳文件的絕對路徑實現(xiàn)方法
- 原生JS和jQuery版實現(xiàn)文件上傳功能
- 微信JSSDK上傳圖片
- 簡單實現(xiàn)js上傳文件功能
- JS文件上傳神器bootstrap fileinput詳解
- js實現(xiàn)上傳圖片之上傳前預(yù)覽圖片
- Javascript圖片上傳前的本地預(yù)覽實例
- 學(xué)習(xí)使用AngularJS文件上傳控件
- JS簡單實現(xiàn)文件上傳實例代碼(無需插件)
- 分享5個好用的javascript文件上傳插件
相關(guān)文章
Ajax高級筆記 JavaScript高級程序設(shè)計筆記
這篇文章主要介紹了Ajax高級筆記 JavaScript高級程序設(shè)計筆記,需要的朋友可以參考下2017-06-06JS實現(xiàn)帶關(guān)閉功能的阿里媽媽網(wǎng)站頂部滑出banner工具條代碼
這篇文章主要介紹了JS實現(xiàn)帶關(guān)閉功能的阿里媽媽網(wǎng)站頂部滑出banner工具條代碼,可實現(xiàn)頂部banner窗口的浮動顯示及關(guān)閉隱藏功能,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09Javascript實現(xiàn)的StopWatch功能示例
這篇文章主要介紹了Javascript實現(xiàn)的StopWatch功能,結(jié)合具體實例形式分析了javascript自定義StopWatch實現(xiàn)測試運行時間功能的相關(guān)操作技巧,需要的朋友可以參考下2017-06-06Array.prototype.concat不是通用方法反駁[譯]
ECMAScript 5.1規(guī)范中指出,數(shù)組方法concat是通用的(generic).本文反駁了這一結(jié)論,因為實際上并不是這樣的2012-09-09有關(guān)JS中的0,null,undefined,[],{},'''''''''''''''',false之間的關(guān)系
這篇文章主要介紹了有關(guān)JS中的0,null,undefined,[],{},'',false之間的關(guān)系,需要的朋友可以參考下2017-02-02