前段时间在解决ajax上传文件时折腾了好一阵。直接用$.post上传文本信息肯定是没有问题的。但是$.post直接上传图片是不可行的。
后来看到网上的一些解决方案,有现成的ajax上传文件的封装的方法也有利用flash的。flash确实是个好方法 但是不是每个人都会flash的而且下载下来现成的方法要做修改也不是件易事,且文件相对较大。最后只好模拟iframe来实现。发现相当的简单。
html:
这里是重点。要上传文件enctype这个属性不可少,target的值改为iframe的name的值。
下面写一下js代码,我是用的jQuery所以在用的时候载入jquery的库是必不可少的。
这里是做了一个浏览器版本的判断,因为IE是不太符合规范的一个浏览器,尤其是IE6。IE6是不直接支持$("#idName").submit();这种方式的。
服务端如下,还得返回一个值,直接submit是无法返回值的