html中进行文件的选择(input.click())

html中的<input type="file"/>标签没法进行定制,因此,比较通用的一种实现方式是将”input file“设置为透明,再在底部添加一个背景节点进行显示

1     <div style="position:relative">
2         <a style="width:100px;height:30px;">请选择文件</a><!--其他标签也可以-->
3         <input type="file" style="position:absolute;top:0px;left:0px;width:100px;height:30px;opacity:0"/>
4     </div>

还有一种比较通用的方式是有别的标签的click时间进行触发实现如下:

 1 !DOCTYPE html>
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3     <head>
 4         <title></title>
 5         <script src="../jquery.js"></script>
 6         <script>
 7             function SelectFile() {
 8                 var promise = $.Deferred();
 9                 var input = $("<input type='file'/>");
10                 if (ischrome) {
11                     //chrome是使用的非阻塞 选择文件是不会中断主线程的js执行的
12                     
13                     input.change(function () {
14                         promise.resolve(this.files);
15                     });
16                     input.click();
17                 } else {
18                     //ie firefo是阻塞的 选择文件会中断主线程的js执行
19                     input.click();
20                     var files = input[0].files;
21                     if (files.length > 0) {
22                         promise.resolve(files);
23                     }
24                 }
25                 return promise;
26             }
27             $(document).ready(function () {
28                 $("button").click(function () {
29                     var selectfile = SelectFile();
30                     selectfile.done(function (files) {
31                         console.log("用户选择的文件为:");
32                         console.log(files);
33                     })
34                 })
35             })
36         </script>
37     </head>
38     <body>
39         <button>请选择文件</button>
40     </body>
41 </html>

 

转载于:https://www.cnblogs.com/zp900704/p/5155521.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值