jQuery 关于文件上传表单处理的一个非常怪异的问题

红薯 发布于 2009/02/23 13:33
阅读 4K+
收藏 3

【开源中国 APP 全新上线】“动弹” 回归、集成大模型对话、畅读技术报告”

jQuery 有个插件 jQuery.Form ,这个插件功能很强大,可以用来处理文件上传的表单。

下面是这个问题的描述:

假设有这么一个表单

<form id="form_img" action="/action/upload" method="POST" enctype="multiple/form-data">
<input type="file" name="img"/><input type="submit" value="上传"/>
</form>

我们可以用下面的脚本来提交

$('#form_img').ajaxForm({
    success: function(html) {
        alert(html);
    }
});

假设上传页面的地址是 http://www.oschina.net/upload.html

那么处理文件上传请求的地址就是 http://www.oschina.net/action/upload

我们引入jquery的js文件的代码如下(为了将所有静态文件独立存放,我们使用了一个 http://static.oschina.net 的域名):

<script type="text/javascript" src="http://static.oschina.net/js/jquery.js?ver=1.3.2"></script>
<script type="text/javascript" src="http://static.oschina.net/js/jquery.form.js?ver=2.21"></script>

接下来选择要上传的文件并点击上传按钮时,后台程序显示文件上传成功,但是页面上有一个 alert(html) 却不执行。

而我们只需要把引入js的代码改为:

<script type="text/javascript" src="/js/jquery.js?ver=1.3.2"></script>
<script type="text/javascript" src="/js/jquery.form.js?ver=2.21"></script>

去掉js文件的主机头后,页面就可以正常显示提示信息。


到此问题描述结束,这个问题花了三个小时才解决,但还是不知道是什么原因导致,我知道这个插件为了处理文件上传做了很多复杂的处理,也没去细看它的源码。

另外我发现这个问题的现象跟Ajax在进行跨域名调用时的现象是一致的,在浏览器端表现为没有任何的提示信息、没有任何反应,但也没报脚本错误之类的信息。

很是困惑,有空要好好看看 jquery.form 这个插件的代码。

加载中
0
阿影

ajaxForm很少用,一般我都不作载入绑定的。

直接用按钮触发, 调用ajaxSubmit是个不错的选择。

0
c
cg20061563

可不可以把 form中的action为空,把原来action中的值,放在

$('#form_img').ajaxForm({
    success: function(html) {
        alert(html);
    }
});中,用js来提交上传表单,如果能的话,应该怎样写呢?

我qq:619758779,急需要。

0
红薯
红薯

可以写
beforeSubmit : function(){
   $('#form_img').attr("action","http://www.oschina.net/upload");
}

0
c
cg20061563

能不能给详细一点,我是刚接触jquery,beforeSubmit : function(){
   $('#form_img').attr("action",http://www.oschina.net/upload);}

这个放在哪里?

0
c
cg20061563

我是想上传后,把一些信息(Servlet处理后的),输出到另一个页面中的一个结点里面。

0
红薯
红薯

$('#form_img').ajaxForm({
   beforeSubmit : function(){
     $('#form_img').attr("action","http://www.oschina.net/upload");
   },
    success: function(html) {
        alert(html);
    }
});

0
c
cg20061563

怎样获得,servlet中返回的值,把它放到target中去?

0
黄平俊
黄平俊

引用来自“cg20061563”的帖子

怎样获得,servlet中返回的值,把它放到target中去?

 直接打印出来呗~~~res.getWriter().print(success);

0
轻耘智科技
轻耘智科技
IE浏览器总是把json变成下载,这是为什么呢?
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部