<input id="inputtest" type="file" accept="image/*"/>
这种方式发现在Android上有一个bug就是如果第二次选择的文件跟上一次是同一个文件,则不会触发onchange事件,如果第二次选择的文件跟上一次不是同一个文件,才会触发onchange事件。 请问如何解决?
<input id="inputtest" type="file" accept="image/*"/>
这种方式发现在Android上有一个bug就是如果第二次选择的文件跟上一次是同一个文件,则不会触发onchange事件,如果第二次选择的文件跟上一次不是同一个文件,才会触发onchange事件。 请问如何解决?
完全遇到了一样的问题,
DOM结构一个btn、一个隐藏的input
btn点击事件触发input的change事件
$("#btn_file").change(function () {//btn_file为隐藏的input
if($(this).val() == ''){//如果没有选择文件则不触发
return false;
}
for(var i=0;i<this.files.length;i++){...}
$(this).val('');//操作结束清空input中的内容
});
onblur,onclick,onchange
ps:这个应该不用判断吧。第一次能获取就获取了。没有理解你的需求
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<input type="file" onchange="if(this.value!=''){console.log(this.value);this.value='';console.dir(this)}">
<script type="text/javascript">
</script>
</body>
</html>
你的意思是如果同一个文件如果要上传两次,第二次不会触发onchange事件?如果是这样的话,就按照楼上说的,上传有返回之后,无论是不是成功都清空input。正常也应该清空的。至于其他的,感觉onchange够了。差不多能触发的方法大家都说了,onblur(这个好像不太合适),onclick比较好。
思路:每次执行完成之后,将 input 的属性value
设置为''
。
代码:
<input type="file" name="uploads" id="inputtest" accept="image/*">
<script>
function changeEvent(e) {
console.log(e);
// 其他代码
// value 值设置为 ''
e.target.value = '';
}
document.addEventListener('change', changeEvent, false);
</script>
每次选择文件(即使同一文件),都可以正常触发 change 事件。
6 回答5.3k 阅读✓ 已解决
9 回答9.5k 阅读
5 回答3.7k 阅读✓ 已解决
4 回答8.1k 阅读✓ 已解决
7 回答10.1k 阅读
4 回答8.9k 阅读
5 回答8.4k 阅读
上传之后不管成功与否都将input的值设为空,
input.value = ""