国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

ajaxFileUpload插件,C#返回Json數(shù)據(jù)報(bào)錯(cuò)問題的解決方案

2020-01-24 00:22:09
字體:
供稿:網(wǎng)友

報(bào)錯(cuò)信息一:jQuery.handleError is not a function

 

上傳圖片的時(shí)候,通過F12,查看到這個(gè)錯(cuò)誤。

解決方案:

jquery版本問題,handlerError只在jquery-1.4.2之前的版本中存在,jquery-1.4.2之后的版本中都沒有這個(gè)函數(shù)了。通過添加下面代碼,解決錯(cuò)誤。

 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]);  } },

示例:

 

報(bào)錯(cuò)信息二:SyntaxError:unexpected token <

解決了上述錯(cuò)誤以后,出現(xiàn)了新的錯(cuò)誤:

 

解決方案:

幾經(jīng)周折,通過查看ajaxFileUpload.js的源碼,我發(fā)現(xiàn)下面這樣一段代碼:

 

這里可以看到,返回的數(shù)據(jù)類型。其中類型為json的時(shí)候,是直接用eval函數(shù)生成Json對(duì)象的,所以我猜測(cè),這里轉(zhuǎn)對(duì)象的時(shí)候,報(bào)錯(cuò)了。于是我在上面添加了一個(gè)alert,看一看未轉(zhuǎn)換之前的數(shù)據(jù)格式是什么樣的。

通過alert彈窗發(fā)現(xiàn),返回?cái)?shù)據(jù)的格式如下:

 

此時(shí)就可以解釋通,為何轉(zhuǎn)換不了對(duì)象了。因?yàn)樗呀?jīng)不是一個(gè)正確的Json格式數(shù)據(jù)了,外面包了一層<pre>標(biāo)簽,導(dǎo)致eval生成Json對(duì)象的時(shí)候解析失敗。

解決的思路為去掉前后<pre>標(biāo)簽,使data變成正確的Json格式數(shù)據(jù),然后再用eval函數(shù)完成Json對(duì)象的生成。

Js代碼方式一(紅色標(biāo)記為去掉<pre>標(biāo)簽):

function FileUpload() { $.ajaxFileUpload({  url: '/Common/Image',  fileElementId: 'upload_img',  dataType: 'content',//此處寫content,是因?yàn)橄胱宎jaxFileUpload直接return data數(shù)據(jù),即帶<pre>標(biāo)簽的數(shù)據(jù)。  success: function(data) {   var reg = /<pre.+?>(.+)<//pre>/g;   var result = data.match(reg);   data = RegExp.$1;   var obj = eval("data=" + data); //轉(zhuǎn)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)部方法,紅色標(biāo)記為去掉<pre>標(biāo)簽):

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>標(biāo)簽的代碼,新添加一種類型,前臺(tái)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瀏覽器進(jìn)行的,當(dāng)我使用火狐瀏覽器的時(shí)候,又出現(xiàn)了新的錯(cuò)誤。

報(bào)錯(cuò)信息三:ReferenceError: $ is not defined

 

解決方案:

沒有看懂錯(cuò)誤信息,通過用最開始的方法,我在ajaxFileUpload.js代碼中寫了alert,彈一下data數(shù)據(jù),發(fā)現(xiàn)數(shù)據(jù)格式變成這樣:

 

<pre>標(biāo)簽的內(nèi)容發(fā)生了變化,所以我改變了思路,通過indexOf定位< >,然后只取標(biāo)簽中間的內(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>標(biāo)簽的代碼 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;}

后來想了想,可以用過大括號(hào)來篩選,這樣更準(zhǔn)確一些吧。

var start = data.indexOf("{");if (start != -1) { var end = data.indexOf("}", start + 1); if (end != -1) {  data = data.substring(start + 1, end); }}

總結(jié)

以上所述是小編給大家介紹的ajaxFileUpload插件,C#返回Json數(shù)據(jù)報(bào)錯(cuò)問題的解決方案,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 潞西市| 光泽县| 洛阳市| 凤翔县| 苏尼特左旗| 肥乡县| 江川县| 九龙城区| 得荣县| 界首市| 柳州市| 辽阳县| 长沙县| 葫芦岛市| 方山县| 吴川市| 奉化市| 湘潭县| 高密市| 磐石市| 东平县| 龙泉市| 临夏县| 田东县| 永胜县| 潍坊市| 正镶白旗| 汶上县| 广河县| 兴安盟| 社旗县| 莱州市| 乌苏市| 阿拉善左旗| 磐安县| 郎溪县| 集安市| 海伦市| 南丰县| 布尔津县| 嘉善县|