前端常见问题
选课中心 APP下载
当前位置:首页 > 技能类 > 前端 > 常见问题 > js清空input file的值

js清空input file的值

更新时间:2020-09-15 11:34:50 来源: 阅读量:

【摘要】 js清空input file的值考必过小编为大家整理了关于js清空input file的值的信息,希望可以帮助到大家!

js清空input file的值

标签:功能document界面选择exceptionpretty需要atilan

原文:js清空input file的值

在做选择本地图片上传的功能时遇到一个问题,第一次点file按钮选择图片完成会触发onchange事件,获取文件后动态在界面上创建img标签展示,但把创建的img元素节点删除后,再点file按钮选择同一个文件后发现图片并没有被重新创建出来。

分析了原因:

因为上一次选择的文件与本次选择的是同一个文件,两次的路径值相同,值没有改变所以导致file不会触发onchange事件,因此需要每次创建完img后重置file的value或者重置file的dom来解决这个问题。

解决方法一:
每次创建完img后把file的value值重置为空字符串

var file = document.getElementById(‘file‘);
file.value = ‘‘; //file的value值只能设置为空字符串

注意:浏览器的安全机制不允许直接用js修改file的value为空字符串以外的值,强制修改会报以下错误:

VM4061:1 Uncaught DOMException: Failed to set the ‘value’ property on ‘HTMLInputElement’: This input element accepts a filename, which may only be programmatically set to the empty string.

解决方法二:
每次创建完img后把file的outerHTML重置 (我自己实验这种方法并不奏效)

var file = document.getElementById(‘file‘);
file.outerHTML = file.outerHTML; //重置了file的outerHTML

js清空input file的值

标签:功能document界面选择exceptionpretty需要atilan

以上就是js清空input file的值的内容,更多资讯请及时关注考必过网站,最新消息小编会第一时间发布,大家考试加油!

分享到: 编辑:huahua