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

jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取

 更新時(shí)間:2017年06月11日 10:00:46   投稿:mrr  
這篇文章主要介紹了jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取 ,需要的朋友可以參考下

XMLHttpRequest Level 2 添加了一個(gè)新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優(yōu)點(diǎn)就是我們可以異步上傳二進(jìn)制文件。

jQuery 2.0+的版本支持FormData

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

•前端(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>

•后臺(tái)(web.py):

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

 注意:

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

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

3.后端通過(guò)web.input獲取文件的字段名,同前端指定的input標(biāo)簽的name屬性

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

有時(shí),我們并不想用

標(biāo)簽,而且通過(guò)ajax傳給后端的并不只有文件,可能還有其他的鍵值對(duì),這時(shí)就可以用這個(gè)方法

•前端(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 () {}
  });
}

•后臺(tái)(web.py):

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

 注意:

1.沒(méi)有<form>標(biāo)簽(有了也不錯(cuò))

2.append()方法的第二個(gè)參數(shù)是文件對(duì)象,在html中已經(jīng)通過(guò)loadFile方法的參數(shù)傳過(guò)來(lái)

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

4.因?yàn)橥ㄟ^(guò)web.input獲取的值都是字符串,如果除文件以外的鍵值對(duì)傳過(guò)來(lái)是null,會(huì)自動(dòng)轉(zhuǎn)化為字符串'null'。這點(diǎn)處理的時(shí)候需要注意

以上所述是小編給大家介紹的jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!

相關(guān)文章

最新評(píng)論