当前位置: 美高梅棋牌 > 智能硬件 > 正文

File控件杂谈

时间:2019-10-03 08:34来源:智能硬件
File杂谈——初识file控件 2015/07/23 · HTML5 ·file控件 原文出处: 百码山庄    首先我说明下,这里介绍的file控件指的是网页中的FileUpload对象,也就是我们常见的input type=”file” 。如果

File杂谈——初识file控件

2015/07/23 · HTML5 · file控件

原文出处: 百码山庄   

首先我说明下,这里介绍的file控件指的是网页中的FileUpload对象,也就是我们常见的<input type=”file”> 。如果你不是想寻找这方面的东西,就可以绕道了。

  我们通常使用<input type='file'/>来实现网页中文件上传功能,用户可以通过点击file控件选择本地文件,当我们提交包含该控件的表单时,浏览器会向服务器发送用户选中的文件。

功能

当我们需要在网页中实现文件上传功能的时候,file控件就可以大显身手了。HTML文档中每添加一个 <input type=”file”> ,实际就是创建了一个FileUpload实例对象。用户可以通过点击file控件选择本地文件,当我们提交包含该file控件的表单时,浏览器会向服务器发送用户选中的本地文件。从而将本地文件传输到服务器,供其他网络用户下载或使用,实现文件上传功能。

  看上面的描述,file控件貌似挺强大的,事实上也是这样的。但实际开发中我们也可以挑出file控件的诸多问题:

美中不足

无可厚非,file控件很强大,给网页上传文件带来了极大的便利。但是,它并非完美!

首先,从控件本身而言,我们可以通过value属性获取到用户选择的文件名称,但出于安全性等因素考虑,该属性无法指定默认值,并且该属性为只读属性。

其次,恐怕也是file控件令很多开发者头疼的地方。file控件在各个主流浏览器之间的表现大有差异,给用户带来的视觉感受大相径庭,而且几乎不可能通过直接修改样式来达到统一,下面我用一张图来更清晰的告诉大家:

图片 1

一目了然了吧?更可恶的是“选择文件”、“Browse…”、“浏览…”三处文字均无法更改!!然而,这仅仅是视觉上的差异,不同浏览器下file控件的行为也存在一些差异:

  • A1、A2、A3、A4、A6,五处我们均可以单击触发文件选择
  • A5 处我们却需要双击才能触发文件选择

总之,file控件从默认视觉效果和交互体验方面来讲,是开发人员和普通用户都很难接受的。

  1、我们可以通过value属性获取用户选择的文件的名称,但出于安全因素,该属性只读,所以也就无法指定默认值。

道高一尺,魔高一丈

既然默认的东西我们都不能接受,那么不能接受的东西我们就要去改变它。

经过无数开发者的不断实践证明,我们不能通过改变宽度,高度,来控制file控件中按钮的尺寸,但是我们可以通过设置file控件的字体大小(font-size)来改变这个按钮的尺寸,更令人可观的是主流浏览器对改变font-size的表现是一致的。

那么,聪明的开发者们就有了应对之策了。

首先,我们从前面表现差异描述中可以发现A2、A4、A6,三处均可单击触发文件选择文件,并且这三处还有一个共同点——它们均处于控件右侧,那么我们就可以改变控件字体大小,让右侧这一部分足够大,并且只让用户看见这一区域(或部分),并且只让用户操作该区域,那么A5处交互效果不一致的问题就可以解决了。为了达到这个目的,我们可以在file控件外面包裹一层容器,并设置尺寸,通过定位将file控件右边区域显示到目标区域,并为容器设置溢出隐藏( overflow: hidden )。我还是用代码来说明吧:

XHTML

<style> .file-group { position: relative; width: 200px; height: 80px; border: 1px solid #ccc; /* 为了显示可见区域,非必须 */ overflow: hidden; } .file-group input { position: absolute; right: 0; top: 0; font-size: 300px; } </style> <div class="file-group"> <input type="file" name="" id="J_File"> </div>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<style>
    .file-group {
        position: relative;
        width: 200px;
        height: 80px;
        border: 1px solid #ccc; /* 为了显示可见区域,非必须 */
        overflow: hidden;
    }
    .file-group input {
        position: absolute;
        right: 0;
        top: 0;
        font-size: 300px;
    }
</style>
<div class="file-group">
    <input type="file" name="" id="J_File">
</div>

在浏览器中查看上面代码的效果,显然Chrome、Firefox、IE下显示效果明显太不一样了(其实文字被放大挤出可见区域了,几乎啥都看不到),那么怎么应对呢?所谓“道高一尺,魔高一丈”,这里简单的原理就是让file控件处于较高的层(z-index),并且设置透明(opacity,低版本IE用filter),让后面的元素来设置样式,以此达到视觉风格统一。说得不是很明白,还是直接上代码吧:

XHTML

<style> .file-group { position: relative; width: 200px; height: 80px; border: 1px solid #ccc; /* 为了显示可见区域,非必须 */ overflow: hidden; cursor: pointer; line-height: 80px; font-size: 16px; text-align: center; color: #fff; background-color: #f50; border-radius: 4px; } .file-group input { position: absolute; right: 0; top: 0; font-size: 300px; opacity: 0; filter: alpha(opacity=0); cursor: pointer; } .file-group:hover { background-color: #f60; } </style> <div class="file-group"> <input type="file" name="" id="J_File"> 选择文件 </div>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<style>
    .file-group {
        position: relative;
        width: 200px;
        height: 80px;
        border: 1px solid #ccc; /* 为了显示可见区域,非必须 */
        overflow: hidden;
        cursor: pointer;
        line-height: 80px;
        font-size: 16px;
        text-align: center;
        color: #fff;
        background-color: #f50;
        border-radius: 4px;
    }
    .file-group input {
        position: absolute;
        right: 0;
        top: 0;
        font-size: 300px;
        opacity: 0;
        filter: alpha(opacity=0);
        cursor: pointer;
    }
    .file-group:hover {
        background-color: #f60;
    }
</style>
<div class="file-group">
    <input type="file" name="" id="J_File">
    选择文件
</div>

最后我们再看下各浏览器表现一致的最终显示效果及交互体验:

图片 2

OK,到这里我们算是对file控件有个简单的认识了,后面我还会提供更多file控件或根据file控件延伸出去的相关资料,有兴趣的朋友可以持续关注。

1 赞 3 收藏 评论

图片 3

  2、最让我们诟病的是,file控件在不同浏览器上长相迥异。这让我们开发者情何以堪?而且“选择文件”、“浏览…”等字样均无法修改。更可恶的是IE9中file控件类似于输入框的位置需要双击才能触发文件选择。这样的视觉效果与交互体验着实让我们无法接受。

  so,目前普遍的解决方案是这样的:

  在file控件外面包裹一层容器,并设置其尺寸,通过定位将file控件右侧区域(因为IE9中file控件左侧区域单击无效)显示到目标区域,并为容器设置溢出隐藏。同时,为了让控件可被点击,我们让file处于较高的层并设置透明,只让容器样式可见,以此达到视觉与交互风格的统一。见代码:

<style type="text/css">
  .container{
      font-family: "microsoft yahei";
      position: relative;
      width:200px;
      height: 80px;
      border:1px solid #ccc;/*为了看上去明显*/
      overflow: hidden;
      line-height: 80px;
      font-size: 16px;
      text-align: center;
      color: #fff;
      background-color: #ccc;
      border-radius: 4px;
  }
  .container:hover{
      background-color: #eee;
  }
  #myFile{
      position: absolute;
      font-size: 300px;
      cursor: pointer;
      right:0;
      top:0;
      opacity: 0;
      filter: alpha(opacity=0);
  }

</style>
<div class="container">
    <input type="file" name="myFile" id="myFile" value="" />
    选择文件
 </div>

  这样我们基本上解决了以上所说的问题了。

  HTML5到来之前,我们对于file控件可以利用的有用数据也就是value属性了,H5给file控件新增了files属性,该属性包含file控件选择的文件对象的集合,其中包括上次修改时间、名称、大小等信息。这极大地方便了我们开发者,还记得以前在公司做一个项目,要控制上传文件大小的时候还需要借助于flash来实现,否则只能等文件上传到服务端了再判断大小,结果很多时候上传了一个很大的文件,页面加载了半天(向后台传递需要走网络,比较耗时),最后还是告诉我文件过大。试想,这样的体验用户孰忍直视?(PS:IE9不支持files属性)

  然而随着技术的发展,我们发现了另外一种可能更符合用户操作习惯的上传文件的方式:拖拽。现在已经有很多网站支持这种方式了。我们看一个演示的例子:

  

<style>
            html,body,div{
                margin:0;
                padding: 0;
            }
            #file{
                display: none;
            }
            .up-area{
                margin:50px auto;
                border: 1px dashed #ccc;
                background-color: #eee;
                width:600px;
                height:400px;
                line-height: 400px;
                text-align: center;
                color: #666;
                cursor: pointer;
            }
            .up-area:hover{
                background-color: #ddd;
            }
        </style>
<input type="file" id="file"/>
        <div class="up-area" id="upArea"></div>
        <script type="text/javascript">
            (function(){
                var area= document.getElementById("upArea"),
                    file = document.getElementById("file");
                function uploadFile(fs){
                    console && console.log(fs);
                }
                area.onclick = function(){
                    console && console.log("click");
                    file.click();
                }
                file.onchange=function(){
                    uploadFile(this.files);
                }
                area.ondragenter = function(e){
                    this.className = "up-area hover";
                    e.preventDefault();
                }
                area.ondragover = function(e){
                    e.preventDefault();
                }
                area.ondrop = function(e){
                    e.preventDefault();
                    console && console.log("drop");
                    var dt = e.dataTransfer;
                    this.className = "up-area";
                    uploadFile(dt.files);
                };
            })();

</script>

编辑:智能硬件 本文来源:File控件杂谈

关键词: