91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jQuery Ajax如何使用FormData上傳文件和其他數據后端web.py

發布時間:2021-05-25 09:46:21 來源:億速云 閱讀:266 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關jQuery Ajax如何使用FormData上傳文件和其他數據后端web.py,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

XMLHttpRequest Level 2 添加了一個新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優點就是我們可以異步上傳二進制文件。

jQuery 2.0+的版本支持FormData

方法一:使用<form>表單初始化FormData對象方式上傳文件

?前端(JQuery):

<form enctype="multipart/form-data">
  <input type="file" name="myfile" onchange="loadFile(this.files[0])">
</form>
<script>
  function loadFile(file){
    var formdata = new FormData($$('form')[0]);
    $.ajax({
      url: 'jobs/add',
      type: 'POST',
      datatype: 'json',
      data: formdata,
      cache:false,
      traditional: true,
      contentType: false,
      processData: false,
      success: function (data) {},
      error: function () {}
    });
  }
</script>

?后臺(web.py):

class Add:
  def POST(self):
    i = web.input(myfile={})
    print(i['myfile'].filename) #文件名
    print(i['myfile'].value) #文件內容
    print(i['myfile'].file.read()) #文件內容

 注意:

1.<form>的enctype屬性需要設置為“multipart/form-data”

2.$.ajax中processData、contentType和cache需要設置為false

3.后端通過web.input獲取文件的字段名,同前端指定的input標簽的name屬性

方法二√:不用<form>,使用FormData對象添加字段方式上傳文件

有時,我們并不想用

標簽,而且通過ajax傳給后端的并不只有文件,可能還有其他的鍵值對,這時就可以用這個方法

?前端(JQuery):

<input type="file" onchange="loadFile(this.files[0])" />
function loadFile(file){
  container.fd = new FormData();
  container.fd.append('myfile',file);
  container.fd.append('otherkey',othervalue);
  $.ajax({
    url: 'jobs/add',
    type: 'POST',
    datatype: 'json',
    data: fd,
    cache:false,
    traditional: true,
    contentType: false,
    processData: false,
    success: function (data) {},
    error: function () {}
  });
}

?后臺(web.py):

class Add:
  def POST(self):
    i = web.input(myfile={}, otherkey='')
    print(i['myfile'].filename) #文件名
    print(i['myfile'].value) #文件內容
    print(i['myfile'].file.read()) #文件內容

 注意:

1.沒有<form>標簽(有了也不錯)

2.append()方法的第二個參數是文件對象,在html中已經通過loadFile方法的參數傳過來

3.后端通過web.input獲取文件的字段名,同前端append()方法的第一個參數

4.因為通過web.input獲取的值都是字符串,如果除文件以外的鍵值對傳過來是null,會自動轉化為字符串'null'。這點處理的時候需要注意

jquery是什么

jquery是一個簡潔而快速的JavaScript庫,它具有獨特的鏈式語法和短小清晰的多功能接口、高效靈活的css選擇器,并且可對CSS選擇器進行擴展、擁有便捷的插件擴展機制和豐富的插件,是繼Prototype之后又一個優秀的JavaScript代碼庫,能夠用于簡化事件處理、HTML文檔遍歷、Ajax交互和動畫,以便快速開發網站。

關于“jQuery Ajax如何使用FormData上傳文件和其他數據后端web.py”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

措勤县| 石家庄市| 左云县| 偃师市| 麻城市| 上杭县| 长子县| 芦山县| 时尚| 富顺县| 阿坝| 诏安县| 毕节市| 扬州市| 康马县| 务川| 镇巴县| 民和| 加查县| 鄯善县| 吐鲁番市| 娱乐| 武胜县| 龙州县| 驻马店市| 庆元县| 开原市| 集安市| 星座| 南岸区| 梁山县| 阿图什市| 天门市| 黄浦区| 合江县| 崇明县| 仪陇县| 高平市| 中江县| 彰化县| 铁力市|