• css input[type=file] 样式美化,input上传按钮美化


    今天的内容是input[type=file] 样式美化,input上传按钮美化。

    我们在做input文本上传的时候,html自带的上传按钮比较丑,如何对其进行美化呢?同理:input checkbox美化,input radio美化是一个道理的,后面文章会总结。

    思路:

    input file上传按钮的美化思路是,先把之前的按钮透明度opacity设置为0,然后,外层用div包裹,就实现了美化功能。

    代码如下:

    DOM结构:

    <a href="javascript:;" class="a-upload"> <input type="file" name="" id="">点击这里上传文件 </a>  <a href="javascript:;" class="file">选择文件     <input type="file" name="" id=""> </a>

    CSS样式1:

    /*a  upload */ .a-upload {     padding: 4px 10px;     height: 20px;     line-height: 20px;     position: relative;     cursor: pointer;     color: #888;     background: #fafafa;     border: 1px solid #ddd;     border-radius: 4px;     overflow: hidden;     display: inline-block; *display: inline; *zoom: 1 }  .a-upload  input {     position: absolute;     font-size: 100px;     right: 0;     top: 0;     opacity: 0;     filter: alpha(opacity=0);     cursor: pointer }  .a-upload:hover {     color: #444;     background: #eee;     border-color: #ccc;     text-decoration: none }

    样式2:

    .file {     position: relative;     display: inline-block;     background: #D0EEFF;     border: 1px solid #99D3F5;     border-radius: 4px;     padding: 4px 12px;     overflow: hidden;     color: #1E88C7;     text-decoration: none;     text-indent: 0;     line-height: 20px; } .file input {     position: absolute;     font-size: 100px;     right: 0;     top: 0;     opacity: 0; } .file:hover {     background: #AADFFD;     border-color: #78C3F3;     color: #004974;     text-decoration: none; }

    修改后如下:

    enter image description here

    样式二:

    enter image description here

    备注:对于HTML5之input:file,还可以控制上传的类型的,但是这个是html5的,低版本浏览器不支持,详情请看:HTML5的 input:file上传类型控制 http://www.haorooms.com/post/input_file_leixing

    美化后显示文件名

    上面美化,把默认显示的文件名也给隐藏掉了,那么如何显示文件名称呢?没关系,我们可以用jquery来获取文件的文件名。

    我们可以写个change事件

    $(".a-upload").on("change","input[type='file']",function(){ var filePath=$(this).val(); if(filePath.indexOf("jpg")!=-1 || filePath.indexOf("png")!=-1){         $(".fileerrorTip").html("").hide(); var arr=filePath.split('\'); var fileName=arr[arr.length-1];         $(".showFileName").html(fileName); }else{         $(".showFileName").html("");         $(".fileerrorTip").html("您未上传文件,或者您上传文件类型有误!").show(); return false } })

    其他input美化文章

    关于 input checkbox和radio样式美化,我也写了一篇文章,请看 http://www.haorooms.com/post/css_mh_ck_radio

    还有input search 右侧有个关闭按钮的美化,可以看http://www.haorooms.com/post/qd_ghfx 第五条。

  • 相关阅读:
    duilib入门简明教程 -- VS环境配置(2) Alberl
    使用libCurl实现断点下载
    通用选择器和高级选择器
    Aforge.net 一个专门为开发者和研究者基于C#框架设计
    iBatis核心框架浅析
    Parameter Binding in ASP.NET Web API(参数绑定)
    图的基本概念
    领域模型中分散的事务如何集中统一处理(C#解决方案)
    .NET 垃圾回收与内存泄漏
    三层架构之泛型抽象工厂
  • 原文地址:https://www.cnblogs.com/momox/p/5644625.html
Copyright © 2020-2023  润新知