欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實(shí)現(xiàn)上傳文件顯示進(jìn)度條

 更新時(shí)間:2022年07月15日 08:34:39   作者:酷愛(ài)編程的小猿同學(xué)  
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)上傳文件顯示進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了JS實(shí)現(xiàn)上傳文件顯示進(jìn)度條的具體代碼,供大家參考,具體內(nèi)容如下

用戶(hù)反饋:圖片上傳過(guò)程中,如果網(wǎng)絡(luò)比較慢,會(huì)發(fā)現(xiàn)上傳圖片后沒(méi)有一點(diǎn)反應(yīng),體驗(yàn)性很差,圖片回顯也比較慢

解決思路:通過(guò)XMLHttpRequest的progress來(lái)實(shí)現(xiàn)監(jiān)聽(tīng)圖片上傳的進(jìn)度,實(shí)時(shí)顯示百分比,后臺(tái)保存圖片成功后再將圖片轉(zhuǎn)為Base64編碼的字符串在前端顯示出來(lái),這樣可以很大程度提高用戶(hù)體驗(yàn)

需要達(dá)到的效果:

1、用戶(hù)可以看到圖片上傳進(jìn)度條百分比

2、提升圖片回顯速度(將圖片轉(zhuǎn)為Base64編碼的字符串在前端顯示)

HTML代碼:

<!-- 上傳input -->
<input class="file-input" name="uploadImage" id="uploadImage" type="file">
<!-- 上傳進(jìn)度條顯示 -->
<a id="showProgress" style="display:none;" href="#"></a>?

JS代碼:

// 上傳input綁定一個(gè)change事件
$("#uploadImage").on("change", uploadPicture());
?
// 上傳方法,里面處理進(jìn)度條邏輯
function uploadPicture() {
? ? var $this= $(this);
? ? document.getElementById("showProgress").style.display="block";
? ? var fd = new FormData();
? ? fd.append("file", $this.context.files[0]);
?
? ? var xhr = new XMLHttpRequest();
? ? //上傳中設(shè)置上傳的百分比
? ? xhr.upload.addEventListener("progress", function(evt){
? ? ? ? if (evt.lengthComputable) {
? ? ? ? ? ? var percentComplete = Math.round(evt.loaded * 100 / evt.total);
? ? ? ? ? ? if (percentComplete == 100){
? ? ? ? ? ? ? ? setTimeout(function () {
? ? ? ? ? ? ? ? ? ? document.getElementById("showProgress").innerHTML = '已上傳'+percentComplete+"%";
? ? ? ? ? ? ? ? },1500)
? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? document.getElementById("showProgress").innerHTML = '已上傳'+percentComplete+"%";
? ? ? ? ? ? }
? ? ? ? }else {
? ? ? ? ? ? document.getElementById("showProgress").innerHTML = '無(wú)法計(jì)算';
? ? ? ? }
? ? }, false);
? ? //請(qǐng)求完成后執(zhí)行的操作
? ? xhr.addEventListener("load", function(evt){
? ? ? ? var message = evt.target.responseText,
? ? ? ? ? ? ? ? obj = eval("("+message+")");
? ? ? ? $("#uploadImage").attr("src",obj);
? ? ? ? document.getElementById("showProgress").style.display="none";
? ? ? ? ?alert("上傳成功!");
?
? ? }, false);
? ? //請(qǐng)求error
? ? xhr.addEventListener("error", uploadFailed, false);
? ? //請(qǐng)求中斷
? ? xhr.addEventListener("abort", uploadCanceled, false);
? ? //發(fā)送請(qǐng)求
? ? xhr.open("POST", /uploadPicture.json);
? ? xhr.send(fd);
? ? }
?
function uploadFailed(evt) {
? ?alert("上傳出錯(cuò).");
}
?
function uploadCanceled(evt) {
? ?alert("上傳已由用戶(hù)或?yàn)g覽器取消刪除連接.");
}

后臺(tái)代碼:

/**
? ? ?* 上傳圖片
? ? ?* @param request
? ? ?* @return
? ? ?*/
? ? @RequestMapping(value = "/uploadPicture", method = RequestMethod.POST)
? ? @ResponseBody
? ? public String uploadPicture(HttpServletRequest request) {
? ? ? ? MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
? ? ? ? Iterator<String> iter = multipartRequest.getFileNames();
? ? ? ? MultipartFile file = null;
? ? ? ? while (iter.hasNext()) {
? ? ? ? ? ? file = multipartRequest.getFile(iter.next());
? ? ? ? }
?
? ? ? ? CommonsMultipartFile cFile = (CommonsMultipartFile) file;
? ? ? ? DiskFileItem fileItem = (DiskFileItem) cFile.getFileItem();
? ? ? ? String filePath = "";
? ? ? ? byte[] data = null;
? ? ? ? String originalFilename = file.getOriginalFilename();
? ? ? ? try {
? ? ? ? ? ? String fileType = originalFilename.substring(
? ? ? ? ? ? ? ? ? ? originalFilename.lastIndexOf(".") + 1).toLowerCase();
?
? ? ? ? ? ? float bb = bytes2kb(file.getSize());
?
? ? ? ? ? ? if (bb > 10) {
? ? ? ? ? ? ? ? throw new Exception("文件上傳失敗,最大上傳大小為10M。");
? ? ? ? ? ? }
?
? ? ? ? ? ? filePath = 上傳圖片方法,這里改為自己公司的;
? ? ? ? ? ??
? ? ? ? ? ? // 轉(zhuǎn)為輸入流
? ? ? ? ? ? InputStream inputStream = fileItem.getInputStream();
? ? ? ? ? ? data = new byte[inputStream.available()];
? ? ? ? ? ? inputStream.read(data);
? ? ? ? ? ? inputStream.close();
? ? ? ? ? ? // 對(duì)字節(jié)數(shù)組進(jìn)行Base64編碼,得到Base64編碼的字符串
? ? ? ? ? ? BASE64Encoder encoder = new BASE64Encoder();
? ? ? ? ? ? String base64Str = encoder.encode(data);
? ? ? ? ? ? return "data:image/jpeg;base64,"+base64Str;
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? }
?
? ? ? ? return null;
? ? }
?
public static float bytes2kb(long bytes) {
?? ??? ?BigDecimal filesize = new BigDecimal(bytes);
?? ??? ?BigDecimal megabyte = new BigDecimal(1024 * 1024);
?? ??? ?float returnValue = filesize.divide(megabyte, 2, 0)
?? ??? ??? ??? ?.floatValue();
?
?? ??? ?return returnValue;
?? ?}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js?實(shí)現(xiàn)picker?選擇器示例詳解

    js?實(shí)現(xiàn)picker?選擇器示例詳解

    這篇文章主要為大家介紹了js?實(shí)現(xiàn)picker?選擇器示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Javascript中的高階函數(shù)介紹

    Javascript中的高階函數(shù)介紹

    這篇文章主要介紹了Javascript中的高階函數(shù)介紹,本文講解了什么是高階函數(shù)、Javascript的高階函數(shù)、還原高階函數(shù)、高階函數(shù)使用實(shí)例等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • 利用js實(shí)現(xiàn)選項(xiàng)卡的特別效果的實(shí)例

    利用js實(shí)現(xiàn)選項(xiàng)卡的特別效果的實(shí)例

    利用js實(shí)現(xiàn)選項(xiàng)卡的特別效果的實(shí)例,需要的朋友可以參考一下
    2013-03-03
  • js作用域和作用域鏈及預(yù)解析

    js作用域和作用域鏈及預(yù)解析

    這篇文章主要介紹了js作用域和作用域鏈及預(yù)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例

    JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例

    這篇文章主要介紹了JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例,文章通過(guò)示例代碼和運(yùn)行效果圖介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Javascript中parseInt的正確使用方式

    Javascript中parseInt的正確使用方式

    今天小編就為大家分享一篇關(guān)于Javascript中parseInt的正確使用方式,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-10-10
  • javascript面向?qū)ο笕筇卣髦庋b實(shí)例詳解

    javascript面向?qū)ο笕筇卣髦庋b實(shí)例詳解

    這篇文章主要介紹了javascript面向?qū)ο笕筇卣髦庋b,簡(jiǎn)單描述了封裝的基本概念、原理,并結(jié)合實(shí)例形式詳細(xì)分析了javascript面向?qū)ο蟪绦蛟O(shè)計(jì)中封裝的用法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-07-07
  • 微信小程序?qū)崿F(xiàn)照片裁剪

    微信小程序?qū)崿F(xiàn)照片裁剪

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)照片裁剪,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 關(guān)于better-scroll插件的無(wú)法滑動(dòng)bug(2021通過(guò)插件解決)

    關(guān)于better-scroll插件的無(wú)法滑動(dòng)bug(2021通過(guò)插件解決)

    這篇文章主要介紹了關(guān)于better-scroll插件的無(wú)法滑動(dòng)bug(2021通過(guò)插件解決),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • 詳解JavaScript如何創(chuàng)建一個(gè)非自動(dòng)播放的GIF網(wǎng)絡(luò)組件

    詳解JavaScript如何創(chuàng)建一個(gè)非自動(dòng)播放的GIF網(wǎng)絡(luò)組件

    這篇文章主要為大家介紹了如何利用JavaScript創(chuàng)建一個(gè)允許您的用戶(hù)決定是否要播放gif的Web組件,文中的實(shí)現(xiàn)步驟講解詳細(xì),需要的可以參考一下
    2022-02-02

最新評(píng)論