是否能够使用jQuery清除<input type='file' />
控制值? 我尝试了如下方法: javascript
$('#control').attr({ value: '' });
但这不起做用。 html
快速解答:更换它。 java
在下面的代码中,我使用replaceWith
jQuery方法将控件替换replaceWith
自身的副本。 若是您有任何绑定到此控件上事件的处理程序,咱们也要保留这些处理程序。 为此,咱们传入true
做为clone
方法的第一个参数。 编程
<input type="file" id="control"/> <button id="clear">Clear</button>
var control = $("#control"); $("#clear").on("click", function () { control.replaceWith( control = control.clone( true ) ); });
小提琴: http : //jsfiddle.net/jonathansampson/dAQVM/ 浏览器
若是克隆在保留事件处理程序的同时出现任何问题,您能够考虑使用事件委托来处理父元素对此控件的单击: 安全
$("form").on("focus", "#control", doStuff);
这样能够避免在刷新控件时将任何处理程序与元素一块儿克隆。 ide
文件输入的值是只读的(出于安全缘由)。 您不能以编程方式将其清空(除非经过调用表单的reset()方法,该方法的做用域不只限于该字段)。 this
这适用于Chrome,FF和Safari spa
$("#control").val("")
可能不适用于IE或Opera .net
在IE8中,为了安全起见,他们将“文件上载”字段设为只读。 参见IE团队博客文章 :
从历史上看,HTML文件上传控件()一直是大量信息泄露漏洞的根源。 为了解决这些问题,对控件的行为进行了两项更改。
为了阻止依赖于“窃取”击键来暗中诱骗用户在控件中键入本地文件路径的攻击,“文件路径”编辑框如今为只读。 用户必须使用“文件浏览”对话框明确选择要上传的文件。
此外,“ Internet区域”中的“上传文件时包括本地目录路径” URLAction已设置为“禁用”。 此更改可防止将潜在敏感的本地文件系统信息泄漏到Internet。 例如,Internet Explorer 8如今仅提交文件名image.png,而不是提交完整路径C:\\ users \\ ericlaw \\ documents \\ secret \\ image.png。
这很简单(在全部浏览器中都可使用[歌剧除外]):
$('input[type=file]').each(function(){ $(this).after($(this).clone(true)).remove(); });
JS小提琴: http : //jsfiddle.net/cw84x/1/