解决在 使用 AjaxFileUploder 插件时,不能获取返回的 json 结果数据

在MVC  项目 中使用 AjaxFileUploader 这个插件时,在上传图片或文件时,在控制器中返回的是 json数据,可是在 ie,或 googleChrome 浏览器中却出现 返回的json数据下载的情况,针对 这个情况,以下是我自己解决的方法:

需要特别注意两个地方:

1. 在返回的 json 数据时,加上 "text/html" 这个参数

 return Json(new
                {
                    success = true,
                    originalName = OriginFileName,
                    original = guid,
                    min = min,
                    max = max
                },"text/html");

2. 在 AjaxFileUploader.js 中的  uploadHttpData: function (r, type)这个方法修改如下:

            //data = eval("data = " + data);

            /*++++++++++++++  以下是修改的代码  ++++++++++++++++++++++++++*/

            var datastr = r.responseText;
            var newdatastr = datastr.replace("<pre>", "").replace("</pre>", "");
            data = newdatastr;

            /*+++++++++++++++  以下是修改的代码 ++++++++++++++++++++++++++*/

 3. 在 前端调用的 ajaxFileUpload 方法时,在回调方法 success 时,要对 返回的 json 字符串进行转换成 json 对象:

 success: function (da) {
            //alert("success");
            //alert(da);
            var aaa = JSON.parse(da);
            //alert(aaa.success);
            //alert(aaa.max);
            //alert(!aaa.success);

             if (!aaa.success) {
                 alert(aaa.error);
             } else {
                 //alert("aaa");
                 $('#imgshow').show();
                 $('#imgshow').append("<img src='" + aaa.max + "' width='100' height='60' />");
                 $("#" + modelimgid).val(aaa.max);
             }
        },

 这样就可以了,上传图片时,如果上传成功就能正确的预览了

 

转载于:https://www.cnblogs.com/wisdo/p/4390391.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值