zoukankan      html  css  js  c++  java
  • 自定义input文件上传样式

    前言

      文件上传是我们经常会用到的功能,但是原生的input样式太丑了,能不能自定义一个input文件上传样式呢?我这里写了两种方法,form表单提交跟ajax异步提交都没有问题,自动上传或者点击上传按钮上传也都没问题

    效果

     

     

    代码编写

    方法1

        <!--
                方法1:
                div : 设置宽高、overflow:hidden;超出的部分被隐藏
                input : 设置层级z-index = 1;设置透明度opacity:0;设置相对定位position:relative;使两个元素重叠
                i : 设置层级z-index = 0;(要比input小)设置相对定位position:relative;使两个元素重叠
                利用div框出大小,input在i上面但透明度为0,当我们点击i时其实是点击到了input但视觉上我们只看到了i
            -->
            <h3>方法1:</h3>
            <form action="upload" method="post" enctype="multipart/form-data">
                <!-- 辅助div,框出显示内容 -->
                <div style=" 20px;height: 20px;overflow:hidden;">
                    <!-- 实际的选择文件input -->
                    <input style="position:relative;z-index :1;opacity:0" onchange="change()" id="file" type="file"
                           name="file"/>
                    <!-- 可视图标 -->
                    <i class="glyphicon glyphicon-open" style="position:relative;top:-22px;z-index :0;font-size: 20px;"></i>
                </div>
                <!-- 文件名 -->
                <br/><span id="fileName"></span>
                <!-- 表单提交按钮 -->
                <br/><input id="but_submit" type="submit" value="上传"/>
            </form>
            <script>
                function change() {
                    //回显文件名
                    $("#fileName").text($("#file").val());
                }
            </script>

    方法2

            <!--
                方法2:
                input : 设置层级display: none;  直接隐藏
                i : onclick="document.getElementById('file2').click();"  图标的click触发input的click
                直接隐藏input,设置图标的click触发input的click,从而达到我们想要的效果
            -->
            <h3>方法2:</h3>
            <form id="uploadForm">
                <!-- 实际的选择文件input -->
                <input style="display: none;" onchange="change2()" id="file2" type="file" name="file"/>
                <!-- 可视图标 -->
                <i class="glyphicon glyphicon-open" style="font-size: 20px;"
                   onclick="document.getElementById('file2').click();"></i>
                <!-- 文件名 -->
                <br/><span id="fileName2"></span>
            </form>
            <script>
                //自动上传
                function change2() {
                    //回显文件名
                    $("#fileName2").text($("#file2").val());
                    //执行上传
                    var form = new FormData(document.getElementById("uploadForm"));
                    $.ajax({
                        url: ctx + "/rack/upload",
                        type: "post",
                        data: form,
                        processData: false,
                        contentType: false,
                        success: function (data) {
                            console.log(data);
                        },
                        error: function (e) {
                            console.log(e);
                        }
                    });
                }
            </script>

      controller

        @PostMapping("upload")
        public ResultModel<Boolean> upload(MultipartFile file) {
            //文件名
            System.out.println(file.getOriginalFilename());
            return ResultModel.of(true);
        }

    总结

      样式还是丑了一点,但这些都不重要,关键是掌握了方法再找个UI小姐姐来帮忙调试,就可以做出任何想要的UI效果啦!

    版权声明

    作者:huanzi-qch
    若标题中有“转载”字样,则本文版权归原作者所有。若无转载字样,本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利.


    捐献、打赏

    请注意:作者五行缺钱,如果喜欢这篇文章,请随意打赏!

    支付宝

    微信


    QQ群交流群

    QQ群交流群
    有事请加群,有问题进群大家一起交流!

  • 相关阅读:
    CSUOJ 2192: Wells弹键盘 (dp)
    Gym101981I Magic Potion(最大流)
    BZOJ2588: Count on a tree 主席树
    C#添加多个Sheet表
    DataTable排序,检索,合并
    检索 COM 类工厂中 CLSID 为 {} 的组件时失败,原因是出现以下错误: 80070005
    C#获取URL参数值
    JQuery爱好者们的福音 jQuery EasyUI 开源插件套装 完全替代ExtJS
    12个ajax弹出层效果
    CSS完美兼容IE6/IE7/FF的通用方法
  • 原文地址:https://www.cnblogs.com/huanzi-qch/p/9842204.html
Copyright © 2011-2022 走看看