jQuery的ajax下載blob文件
來源:易賢網 閱讀:4014 次 日期:2016-07-29 16:20:53
溫馨提示:易賢網小編為您整理了“jQuery的ajax下載blob文件”,方便廣大網友查閱!

這篇文章主要介紹了jQuery的ajax下載blob文件的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

乍一聽有點蒙,之前用ng和react時也寫過類似的功能,但是很順利(所以忘記具體細節了)。jquery為啥會不行呢?看了一下具體場景,發現原來jq的ajax回調已經把response的數據傻瓜式的以字符串的方式解析了。

查了一下gg,發現國內的解決方案就是在該場景下不實用jq,而是自己手動創建XMLHttpRequest。雖然這個方法很可靠,但之前封裝的jq的ajax就不能使用了。

查了查jq的文檔,本打算自己根據jq提供的jQuery.ajaxSetup()接口來拓展數據類型,但怎么都搞不定。后來,在github上找到了一個大牛封裝好的jq插件。

然后我們就可以這么寫了:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>blob demo</title>

</head>

<body>

<img id="img" src="" />

<script src="http://cdn.bootcss.com/jquery/2.2.1/jquery.js" charset="utf-8"></script>

<script src="jquery-ajax-blob-arraybuffer.js"></script>

<script type="text/javascript">

$.ajax({

url: "./face.jpg",

type: "get",

dataType: "blob", //擴展出了blob類型

}).done(function(data, status, jqXHR){

var reader = new window.FileReader();

reader.readAsDataURL(data);

reader.onloadend = function() {

document.getElementById("img").src=reader.result;

}

}).fail(function(jqXHR, textStatus) {

console.warn(textStatus);

});

</script>

</body>

</html>

不過,從該插件的源碼上來看,它也是手動構建了一個XMLHttpRequest對象來發送ajax,不過兼容性可能會成為問題。想深究的可以看這里。

以上所述是小編給大家介紹的jQuery的ajax下載blob文件 ,希望對大家有所幫助

更多信息請查看網絡編程
易賢網手機網站地址:jQuery的ajax下載blob文件
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看