h5圖片上傳簡易版(FileReader+FormData+ajax)

来源:https://www.cnblogs.com/wyp-AY/archive/2018/07/08/9281426.html
-Advertisement-
Play Games

h5圖片獲取展示,非同步上傳至伺服器。( 如果有問題,歡迎留言 ^_^ ) ...


一、選擇圖片(input的file類型

<input type="file" id="inputImg">

1. input的file類型會渲染為一個按鈕和一段文字。點擊按鈕可打開文件選擇視窗;file類型的input會有files屬性,保存著文件的相關信息。

2. input.files是一個數組,由傳入的file對象組成。每個file對象包含以下屬性:

lastModified:數值,表示最近一次修改時間的毫秒數;

lastModifiedDate:對象,表示最後一次修改時間的Date對象(高程中說是字元串,根據上圖可看出應該為對象,為了層級清晰未對其展開,大家可自行查看,其可調用Date對象的有關方法,例如getDay方法);

name:本地文件系統中的文件名;

size:文件的位元組大小;

type:字元串,文件的MIME類型;

weblitRelativePath:此處為空;當在input上加上webkitdirectory屬性時,用戶可選擇文件夾,此時weblitRelativePath表示文件夾中文件的相對路徑。比如:

二、讀取圖片數據 (FileReader對象)

FileReader  對象是一種非同步文件讀取機制,使用 File或 Blob對象指定要讀取的文件或數據,結合input:file可以很方便的讀取本地文件。

var reader = new FileReader();//創建一個FileReader實例
reader.readAsDataURL(file);//調用fileReader對象的方法,將文件讀取為DataURL
reader.onload = function(){//處理事件
  console.log(this.result);//讀取完成後,數據保存在對象的result屬性中,列印結果如下:(截取部分結果)
}

三、上傳圖片   ( formData對象 )

1. 用一些鍵值對來模擬一系列表單控制項,以key與value形式組裝成一個對象,FormData對象的操作方法,全部在原型中,自己本身沒任何的屬性及方法。

2. 非同步上傳二進位文件。

3. 屬性不是直接掛載在你這個FormData實例上。可以通過它提供的迭代器,或者get方法去取值。

var formData=new FormData();//創建一個空對象實例
formData.append('key',value);//向該對象添加欄位
console.log(formData.get("key")); // 列印key值對應的value值

4. formData操作

(1)獲取值:通過formData.get(key)/getAll(key)來獲取對應的value

(2)添加數據:通過formData.append(key, value)來添加數據,如果指定的key不存在則會新增一條數據,如果key存在,則添加到數據的末尾

(3)修改數據:通過formData.set(key, value)來設置修改數據,如果指定的key不存在則會新增一條,如果存在,則會修改對應的value值

(4)判斷是否該數據:通過formData.has(key)來判斷是否對應的key值

(5)刪除數據:通過formData.delete(key),來刪除數據

(6)遍曆數據:通過formData.entries()來獲取一個迭代器,然後遍歷所有的數據

(7)發送數據:ajax非同步請求

四、jQuery上傳圖片代碼

var formdata;
if (typeof FileReader === 'undefined') {//檢測瀏覽器對FileReader相容性
        showimg.innerHTML = "抱歉,你的瀏覽器不支持 FileReader";
        imginput.setAttribute('disabled', 'disabled');
} 
else {
    imginput.addEventListener('change', function() {
        var file = this.files[0];
        console.log(file);
        if (!/image\/\w+/.test(file.type)) {
            alert("請確保文件為圖像類型");
            return false;
        }
        var reader = new FileReader();//創建一個FileReader實例
       reader.readAsDataURL(file);//將文件內容進行base64編碼後輸出
       //console.log(reader) 
       reader.onload = function(e) {
           //console.log(this.result);//讀取完成後,數據保存在對象的result屬性中 
          $(showimg).append('<img src="' + this.result + '" alt=""/>');//將選中的圖片顯示在頁面上 //alert('111');  
           formData=new FormData(); 
          formData.append('file',file); 
          console.log(formData.getAll('file')); 
       } 
   }, false); 
}
$.ajax({
    url : url,
    type : 'post',
    dataType:"json", 
    data:formData,
    cache: false,
    processData : false,// 告訴jQuery不要去處理髮送的數據 
    contentType : false,// 告訴jQuery不要去設置Content-Type請求頭
    success : function(data, status, xhr) {
        //alert(1);
    },
    error : function(xhr, errorType, error) {
        //alert(0);
    }
});

 


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

-Advertisement-
Play Games
更多相關文章
  • git上clone一個Gradle項目,使用AS的gradle sync報錯如下: 原因:本地gradle版本不匹配。 解決方法:修改根目錄下的build.gradle 中的classpath為本地已經下載的gradle版本或者本地下載安裝依賴版本。 ...
  • 1、 前言 如果你對App優化比較敏感,那麼Apk安裝包的大小就一定不會忽視。關於瘦身的原因,大概有以下幾個方面: 對於用戶來說,在功能差別不大的前提下,更小的Apk大小意味更少的流量消耗,也意味著更多的用戶下載; 對於產品來說,大於競品的Apk意味著較低的下載基數,不利於驗證產品策略; 對於開發人 ...
  • 在學習Android軟體安全的過程中,經常要用到Android的動態調試。但是呢,一般的Android應用在發佈的時候都是發佈版的不能直接被調試,為了能使Android應用能夠支持調試就需要對Android應用進行解包以及打包加android:debuggable="true"屬性處理,比較煩的是有 ...
  • 版權聲明:未經博主允許不得轉載 在Android中我們常常用到很多UI控制項,如 ,`EditText ImageView Button ImageButton ToggleButton CheckBox RadioButton`等等這些可以自己多用就會了。 也會學到一些佈局如: ,`Relative ...
  • [android 休眠喚醒機制分析(二) — early_suspend ](https://blog.csdn.net/g_salamander/article/details/7982170) 是Android休眠流程的第一階段即淺度休眠,不會受到wake_lock的阻止,一般用於關閉lcd、t ...
  • 上一篇我們創建好了一個新項目。 現在用VScode打開這個目錄並且觀察: node_modules :node 各類依賴包 resources :android/ios 資源(更換圖標和啟動動畫) src:開發工作目錄,頁面、樣式、腳本和圖片都放在這個目錄下 www:靜態文件 platforms:生 ...
  • 分組 在使用正則的時候,有時候會想要匹配一串字元串連續出現多次的情況,比如:我想匹配字元串 連續出現3次的情況。 有些人會直接寫: 但是,這種情況僅僅會匹配 加上三個 ,顯然,這樣是錯誤的。 要想實現之前的需求,我們需要使用正則表達式的分組功能:使用 可以達到分組的功能,使量詞作用於分組。所以,如下 ...
  • offset大家族 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...