加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

上传文件中使用ajaxfileupload.js碰到的问题

发布时间:2020-12-16 01:49:02 所属栏目:百科 来源:网络整理
导读:在做上传图片时需要用到异步上传值服务器,当时选用了ajax的ajaxfileupload可以上传。 这里写下踩过的坑 1:使用 $.ajaxFileUpload({}); 函数,网页报错,提示没有这个函数。 解决:导入ajaxfileupload.js文件。简单 2:上传成功了没有执行回调,即$.ajaxFil

在做上传图片时需要用到异步上传值服务器,当时选用了ajax的ajaxfileupload可以上传。
这里写下踩过的坑
1:使用$.ajaxFileUpload({});函数,网页报错,提示没有这个函数。
解决:导入ajaxfileupload.js文件。简单
2:上传成功了没有执行回调,即$.ajaxFileUpload({
url:”,//你处理上传文件的服务端
type: ‘POST’,
fileElementId:’file’,#文件在html中的id
dataType: ‘json’,
data:{需要上传的数据},#可以省略
success: function(data) {
},
failure: function(data) {
}
});中success函数。上网查,说是需要修改ajaxfileupload.js的源代码。好吧试试
在uploadHttpData: function( r,type ) {
var data = !type;
data = type == “xml” || data ? r.responseXML : r.responseText;
if ( type == “json” )
eval( “data = ” + data );
},
看eval函数代码
function eval(s){return new Object();};
什么都没有返回,注释掉,网上说换成这个

if(type=="json"){data=data.replace("<pre>","").replace("</pre>","");}
这个data.replace("<pre>","");replace是因为文件上传的话返回的json字符串会带有<pre>开头的一串字符,但是我没有得到过哦。所以可以这样写:
if(type=="json"){data=data;}
这样就可以执行回调函数了。

3:上传的文件大于2M报错,提示文件太大。哎呀,现在的图片那个不是2,3M的,矫情!
解决:在struts文件里加上这个。500M都可以了。哈哈(这里有很多种解决办法,可以上网搜索哦)
好了,结束手工!
附上ajaxfileuploa.js文件(修改后的)http://download.csdn.net/detail/u011575570/9241787

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读