jquery清空file内容_使用jQuery清除input type = file /

文章目录

是否可以使用jQuery清除< input type ='file'/>控制值?我已经尝试了以下内容:$('#control').attr({ value: '' });

但它不起作用。

简单:在元素周围包装一个< form>,调用窗体上的reset,然后使用unwrap()移除窗体。与此线程中的clone()解决方案不同的是,最后会得到相同的元素(包括设置的自定义属性)。

测试并在Opera,Firefox,Safari,Chrome和IE6 +上工作。也适用于其他类型的表单元素,除了type =“hidden”。function resetFormElement(e) {

e.wrap('

').closest('form').get(0).reset();

e.unwrap();

// Prevent form submission

e.stopPropagation();

e.preventDefault();

}

正如下面的Timo所指出的,如果你有按钮来触发< form>中字段的重置,你必须在事件上调用preventDefault来防止<按钮>触发提交。

Edit

由于一个不固定的错误,在IE 11中不起作用。文本(文件名)在输入上被清除,但是其File列表仍然填充。

快速回答:替换它。

在下面的代码中,我使用replaceWith

jQuery方法替换控制与自己的克隆。如果您有任何处理程序绑定到此控件上的事件,我们也想保留这些。为此,我们传入true作为clone的第一个参数,代码>方法。

Clear

var control = $("#control");

$("#clear").on("click", function () {

control.replaceWith( control = control.clone( true ) );

});

如果在克隆的同时保留事件处理程序,则可能会考虑使用事件委托来处理父元素对此控件的点击:$("form").on("focus", "#control", doStuff);

这样可以防止在刷新控件时需要将任何处理程序与元素一起克隆。

未经作者同意,本文严禁转载,违者必究!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值