问题说明:
在一个form表单中需要发送两种enctype的请求,因此就需要对form表单的enctype进行动态修改。具体做法如下:
1.需要发送application/x-www-form-urlencoded的请求:
function delete()
{
fm.setAttribute('enctype','application/x-www-form-urlencoded');
fm.enctype = "application/x-www-form-urlencoded";
fm.action = "./xxxx.jsp?operate=delete";
fm.submit();
}
2.需要发送multipart/form-data的请求:
function print() {
fm.setAttribute('enctype','multipart/form-data');
fm.enctype = "multipart/form-data";
fm.action = "./xxxExport.jsp";
fm.submit();
}
问题在于在IE浏览器上这种动态修改方式不能生效。
问题解决:
上传文件动态设置enctype
IE中form没有enctype属性,只有encoding属性,那么以上代码改写为:
if(fm.encoding){
fm.setAttribute('encoding','multipart/form-data');
}else{
fm.setAttribute('enctype','multipart/form-data');
}
或者更粗暴的方式:
fm.setAttribute('enctype','multipart/form-data');
fm.setAttribute('encoding','multipart/form-data');
全都设置了!!