javascript - jquery 如何打开input的file选择框?
ringa_lee
ringa_lee 2017-04-10 17:04:07
[JavaScript讨论组]

我先是写了一个

<input type="file" name="file" id="fileupdate" />

然后我写了一个a标签,在jquery 写的内容是

$('a').on('click', '', function() {
    $('#fileupdate').click();
});

但是吧,点击后没有任何的反应?


好吧,最终只能用abs定位解决了...效果是实现了,就是有点不开心。

请问大家下,选择文件后,jquery使用什么触发我接下来的操作,比如获取file文件。我使用什么触发?

ringa_lee
ringa_lee

ringa_lee

全部回复(5)
迷茫

参考此问题
http://segmentfault.com/q/1010000004322570
js 产生的点击事件不能调出上传文件选择框。

你可以观察一下,js 产生的点击事件 event.isTrusted == false,而你在浏览器中真实的点击事件event.isTrusted == true

你可以参考在隐藏的文件输入框上调用click()方法

PHPz

的确用 Javascript 无法直接触发 file 弹框

但是题主想问的是用a标签触发file弹框

这样就可以

<script src="http://libs.useso.com/js/jquery/1.11.1/jquery.min.js"></script>

<input type="file" name="file" id="fileupdate" />
<a id="select">select</a>
<script>

    function select(){
        return  $('#fileupdate').click();
    }
    
    $('#select').on('click', '', function() {
        select();
    });
</script>
阿神

答案是:无解!你无法用任何 Javascript 触发 file 弹框,在任何浏览器都不!

这不是 BUG,这么做是出于安全考虑

不过,你可以通过在a下面创建一个隐藏的input模拟该效果

例子

参考:http://stackoverflow.com/questions/210643/in-javascript-can-i-make-a-click-event-fire-programmatically-for-a-file-input

迷茫

a标签- -。语义化呢,为啥不用label,直接for属性设置那个input file就行了,连js都不用

PHP中文网

.. 直接去的input元素 创建click事件就可以了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号