ajaxFileUpload插件,C#返回Json數(shù)據(jù)報錯問題的解決方案
報錯信息一:jQuery.handleError is not a function
上傳圖片的時候,通過F12,查看到這個錯誤。
解決方案:
jquery版本問題,handlerError只在jquery-1.4.2之前的版本中存在,jquery-1.4.2之后的版本中都沒有這個函數(shù)了。通過添加下面代碼,解決錯誤。
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]);
}
},
示例:
報錯信息二:SyntaxError:unexpected token <
解決了上述錯誤以后,出現(xiàn)了新的錯誤:
解決方案:
幾經(jīng)周折,通過查看ajaxFileUpload.js的源碼,我發(fā)現(xiàn)下面這樣一段代碼:
這里可以看到,返回的數(shù)據(jù)類型。其中類型為json的時候,是直接用eval函數(shù)生成Json對象的,所以我猜測,這里轉對象的時候,報錯了。于是我在上面添加了一個alert,看一看未轉換之前的數(shù)據(jù)格式是什么樣的。
通過alert彈窗發(fā)現(xiàn),返回數(shù)據(jù)的格式如下:
此時就可以解釋通,為何轉換不了對象了。因為它已經(jīng)不是一個正確的Json格式數(shù)據(jù)了,外面包了一層<pre>標簽,導致eval生成Json對象的時候解析失敗。
解決的思路為去掉前后<pre>標簽,使data變成正確的Json格式數(shù)據(jù),然后再用eval函數(shù)完成Json對象的生成。
Js代碼方式一(紅色標記為去掉<pre>標簽):
function FileUpload() {
$.ajaxFileUpload({
url: '/Common/Image',
fileElementId: 'upload_img',
dataType: 'content',//此處寫content,是因為想讓ajaxFileUpload直接return data數(shù)據(jù),即帶<pre>標簽的數(shù)據(jù)。
success: function(data) {
var reg = /<pre.+?>(.+)<\/pre>/g;
var result = data.match(reg);
data = RegExp.$1;
var obj = eval("data=" + data); //轉josn
if (obj.error == 1) {
$("#images_src").attr("src", obj.msg);
$("#img_path").val(obj.msg);
} else {
alert("失敗");
}
},
error: function(data, status, e) {
alert(e);
}
});
return false;
}
Js代碼方式二(通過修改ajaxFileUpload內(nèi)部方法,紅色標記為去掉<pre>標簽):
uploadHttpData: function(r, type) {
var data = !type;
data = type == "xml" || data ? r.responseXML : r.responseText;
// If the type is "script", eval it in global context
if (type == "script")
jQuery.globalEval(data);
// Get the JavaScript object, if JSON is used.
if (type == "json")
eval("data = " + data);
// evaluate scripts within html
if (type == "html")
jQuery("<div>").html(data).evalScripts();
//此處是去掉<pre>標簽的代碼,新添加一種類型,前臺js的dataType類型寫content,即dataType: 'content'
if (type == "content") {
var reg = /<pre.+?>(.+)<\/pre>/g;
var result = data.match(reg);
data = RegExp.$1;
eval("data = " + data);
}
return data;
}
以上是在QQ瀏覽器進行的,當我使用火狐瀏覽器的時候,又出現(xiàn)了新的錯誤。
報錯信息三:ReferenceError: $ is not defined
解決方案:
沒有看懂錯誤信息,通過用最開始的方法,我在ajaxFileUpload.js代碼中寫了alert,彈一下data數(shù)據(jù),發(fā)現(xiàn)數(shù)據(jù)格式變成這樣:
<pre>標簽的內(nèi)容發(fā)生了變化,所以我改變了思路,通過indexOf定位< >,然后只取標簽中間的內(nèi)容。代碼如下:
uploadHttpData: function(r, type) {
var data = !type;
data = type == "xml" || data ? r.responseXML : r.responseText;
// If the type is "script", eval it in global context
if (type == "script")
jQuery.globalEval(data);
// Get the JavaScript object, if JSON is used.
if (type == "json")
eval("data = " + data);
// evaluate scripts within html
if (type == "html")
jQuery("<div>").html(data).evalScripts();
//此處是去掉<pre>標簽的代碼
if (type == "content") {
//------以下是修改的代碼------
var start = data.indexOf(">");
if (start != -1) {
var end = data.indexOf("<", start + 1);
if (end != -1) {
data = data.substring(start + 1, end);
}
}
eval("data = " + data);
}
return data;
}
后來想了想,可以用過大括號來篩選,這樣更準確一些吧。
var start = data.indexOf("{");
if (start != -1) {
var end = data.indexOf("}", start + 1);
if (end != -1) {
data = data.substring(start + 1, end);
}
}
總結
以上所述是小編給大家介紹的ajaxFileUpload插件,C#返回Json數(shù)據(jù)報錯問題的解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
上一篇:C# 字符串的連接(實例講解)
欄 目:C#教程
本文標題:ajaxFileUpload插件,C#返回Json數(shù)據(jù)報錯問題的解決方案
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5316.html
您可能感興趣的文章
- 01-10使用C#代碼獲取存儲過程返回值
- 01-10C#調用存儲過程詳解(帶返回值、參數(shù)輸入輸出等)
- 01-10C# 7.0 新特性1之基于Tuple的“多”返回值方法
- 01-10快速解決owin返回json字符串多帶了雙引號"多了重string轉義
- 01-10C#打開php鏈接傳參然后接收返回值的關鍵代碼
- 01-10C#的Process類調用第三方插件實現(xiàn)PDF文件轉SWF文件
- 01-10webBrowser執(zhí)行js的方法,并返回值,c#后臺取值的實現(xiàn)
- 01-10c# 兩個數(shù)組比較,將重復部分去掉,返回不重復部分的實現(xiàn)
- 01-10C#微信開發(fā)之接收 / 返回文本消息
- 01-10C# Fiddler插件實現(xiàn)網(wǎng)站離線瀏覽功能


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 01-10C#中split用法實例總結
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改


