亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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) #文件內(nèi)容
    print(i['myfile'].file.read()) #文件內(nèi)容

 注意:

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

2.$.ajax中processData、contentType和cache需要設(shè)置為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) #文件內(nèi)容
    print(i['myfile'].file.read()) #文件內(nèi)容

 注意:

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

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

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

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

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

相關(guān)文章

  • 關(guān)于jQuery中的end()使用方法

    關(guān)于jQuery中的end()使用方法

    最近在學(xué)習(xí)jQuery方面的知識,學(xué)習(xí)中遇到一定的困難,一些知識不得不查看官方的文檔,在用到end()方法時,被一個小例子搞得有點暈。
    2011-07-07
  • jquery實現(xiàn)漂浮在網(wǎng)頁右側(cè)的qq在線客服插件示例

    jquery實現(xiàn)漂浮在網(wǎng)頁右側(cè)的qq在線客服插件示例

    很實用的一款QQ在線客服代碼,點擊QQ圖標,可直接與客服對話,詳細如下,感興趣的朋友可以參考下哈,希望對你有所幫助
    2013-05-05
  • jQuery中innerHeight()方法用法實例

    jQuery中innerHeight()方法用法實例

    這篇文章主要介紹了jQuery中innerHeight()方法用法,實例分析了innerHeight()方法的功能、定義及獲取第一個匹配元素內(nèi)部區(qū)域高度的使用技巧,需要的朋友可以參考下
    2015-01-01
  • jQuery實現(xiàn)簡單日歷效果

    jQuery實現(xiàn)簡單日歷效果

    這篇文章主要為大家詳細介紹了jQuery實現(xiàn)簡單日歷效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • 基于jQuery1.9版本如何判斷瀏覽器版本類型

    基于jQuery1.9版本如何判斷瀏覽器版本類型

    在jquery.1.9以前的版本,可以使用$.browser很輕松的判斷瀏覽器的類型和版本,但是在1.9中和以后的版本中,$.browser已經(jīng)被刪除,下面就介紹一下如何實現(xiàn)此功能,希望能夠給需要的朋友帶來幫助
    2016-01-01
  • 使用jquery+iframe做一個ajax上傳效果(實例)

    使用jquery+iframe做一個ajax上傳效果(實例)

    下面小編就為大家?guī)硪黄褂胘query+iframe做一個ajax上傳效果(實例)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • jQuery文本框得到與失去焦點動態(tài)改變樣式效果

    jQuery文本框得到與失去焦點動態(tài)改變樣式效果

    這篇文章主要介紹了jQuery文本框得到與失去焦點動態(tài)改變樣式效果,涉及jQuery針對頁面表單元素樣式的動態(tài)操作技巧,需要的朋友可以參考下
    2016-09-09
  • Jquery-data的三種用法

    Jquery-data的三種用法

    本篇文章主要介紹了Jquery-data的三種用法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • jQuery實現(xiàn)鼠標移到某個對象時彈出顯示層功能

    jQuery實現(xiàn)鼠標移到某個對象時彈出顯示層功能

    這篇文章主要介紹了jQuery實現(xiàn)鼠標移到某個對象時彈出顯示層功能,涉及jQuery基于事件響應(yīng)動態(tài)操作頁面元素屬性相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2018-08-08
  • checkbox:click事件觸發(fā)span元素內(nèi)容改變的方法

    checkbox:click事件觸發(fā)span元素內(nèi)容改變的方法

    下面小編就為大家?guī)硪黄猚heckbox:click事件觸發(fā)span元素內(nèi)容改變的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09

最新評論