Thinkphp結合ajaxFileUpload實現(xiàn)異步圖片傳輸示例
前言
在做這個項目之前,對圖片上傳處理一直都是直接用表單提交的方式進行文件傳輸,這次因為需求,需要實現(xiàn)對圖片進行異步傳輸,雖然實現(xiàn)并不難,畢竟現(xiàn)在插件太多了,但還是浪費了我很長的調(diào)試時間,原因便是使用了遠古時期的插件ajaxfileupload,在剛開始使用的時候頻繁報錯,說handler is not a function。
懷著沉重的心情,我百度了一下,然后就找到了答案,不禁感概搜索引擎真是強大。
解決方法
上述報錯的原因便是jquery從1.9.0開始便不再使用handler這個方法了,具體原因未知,所以只能在下載下來的 jQuery.extend({
里手動添加代碼:
handleError: function( s, xhr, status, e ){ // If a local callback was specified, fire it if ( s.error ) { s.error.call( s.context || s, xhr, status, e ); } // Fire the global callback if ( s.global ) { (s.context ? jQuery(s.context) : jQuery.event).trigger( "ajaxError", [xhr, s, e] ); } }
,繼續(xù)debug
$.ajaxfileupload({ url : '', secureuri : '', fileElementId : '', --> 這里填的是 input file的ID data : {}, dataType : 'json', complete : function(data){} })
代碼不在報錯了,但又有新的問題,返回的數(shù)據(jù)一直是undefined,隨后看了下調(diào)試工具,返回值存在,而且格式也沒問題,怎么都想不明白之后,又去..................百度了,
然后做了兩個調(diào)整:
1,將ajaxfileupload.js里的 eval('data = '+ data) ;
替換成 data = jQuery.parseJSON(jQuery(data).text());
2,將complete方法換成success
ok,后端返回的數(shù)據(jù)可以打印了。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者使用Swift能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
php實現(xiàn)使用正則將文本中的網(wǎng)址轉(zhuǎn)換成鏈接標簽
本文給大家分享一段php中使用正則表達式將網(wǎng)址轉(zhuǎn)換成A鏈接的函數(shù)代碼,十分簡潔實用,這里推薦給大家2014-12-12php實現(xiàn)把數(shù)組按指定的個數(shù)分隔
這篇文章主要介紹了php實現(xiàn)把數(shù)組按指定的個數(shù)分隔。需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02PHP中include/require/include_once/require_once使用心得
include() 、require()語句包含并運行指定文件。這兩結構在包含文件上完全一樣,唯一的區(qū)別是對于錯誤的處理。require()語句在遇到包含文件不存在,或是出錯的時候,就停止即行,并報錯。include()則繼續(xù)即行。2016-08-08php mysql實現(xiàn)mysql_select_db選擇數(shù)據(jù)庫
在PHP中,與MySQL服務器建立連接后,需要確定所要連接的數(shù)據(jù)庫,此時我們可以使用mysql_select_db函數(shù),該函數(shù)用于選擇需要操作的數(shù)據(jù)庫,需要的朋友可以參考下2016-12-12