问题说明:
在一个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');
全都设置了!!
本文介绍了在Internet Explorer浏览器中动态修改HTML表单enctype属性的方法,以支持不同类型的文件上传需求。文中提供了两种实现方式,并针对IE浏览器特性进行了特别说明。
935

被折叠的 条评论
为什么被折叠?



