js动态在form上插入enctype=multipart/form-data的问题
JS 问题 动态 Data 插入 Form Multipart
2023-06-13 09:14:33 时间
我们都知道要让form能提交文件,需要在form上指定enctype=multipart/form-data的attribute,这样才能上传文件,关于enctype的文章很多,就不再做解释。
问题是因为使用了MVC的Html.BeginForm()来输出表单代码,默认是没有加入enctype的,
复制代码代码如下:
问题是因为使用了MVC的Html.BeginForm()来输出表单代码,默认是没有加入enctype的,
@using(Html.BeginForm()){
}
在PartialView中有一个<inputtype="file"/>用来上传文件,又不想为了这个PartialView去修改父页面的Html.BeginForm(),我的做法是在PartialView中用脚本来为form加入enctype:
$(function(){
$("#file").parents("form").attr("enctype","multipart/form-data");
});
最近的主流浏览器都测试通过没问题,唯独IE的几个旧版本出问题,试了手工在Html.BeginForm()中加入enctype是可以解决问题的,说明问题出在以上的脚本。多方查找终于发现出题出现在于IE6,7,8不支持直接attr("enctype","multipart/form-data"),而是设置dom属性encoding="multipart/form-data",最终的脚本代码修改为:
$(function(){
$("#file").parents("form").attr("enctype","multipart/form-data").get(0).encoding="multipart/form-data";
});
相关文章
- ajax跨域问题以及解决方案_js跨域请求的三种方法
- js全局变量在其他方法中赋值后无法影响到该方法外的全局变量的值(奇葩问题)
- Node.js的fs文件系统
- net/sf/json/jsonobject_js获取json对象的值
- JS获取当前年份_js获取当前时间年月日
- js 数组去除重复数据-5 个提升你 JS 编码水平的实例
- 括号匹配算法的JS简单实现
- js格式化iso 8601格式的日期为其他格式-处理默认golang time类型格式问题
- 让我欲罢不能的node.js详解编程语言
- Oracle中使用JS变量管理数据(oracle使用js变量)
- php和js交互一例-PHP教程,PHP应用
- JSP与JS交互问题值传递
- js类的静态属性和实例属性的理解
- js跨域问题之跨域iframe自适应大小实现代码
- 从js向Action传中文参数出现乱码问题的解决方法
- js中数组(Array)的排序(sort)注意事项说明
- 探讨js字符串数组拼接的性能问题