首页 web前端 html教程 html文件上传小技巧/原生态_html/css_WEB-ITnose

html文件上传小技巧/原生态_html/css_WEB-ITnose

Jun 21, 2016 am 08:48 AM

引语:大家都知道,html中上传文件就一个input,type=file就搞定了。但是,这个标签的样式,实在不值得提点什么,要改动他的样式,恐怕也是较难的。但是其实挺简单,今天就来说说上传文件小技巧吧!1. 怎样自定义样式?

1. 只管按照自己喜欢看到的样式去定义即可,如,可以是背景图片效果,可以是文字指示,总之想怎么改怎么改!有了按钮,还需要一个文件名容器,用来存放选择上传文件时的名字,从而不让上传看起来枯涩难懂。2. 添加真正需要上传的文件控件,并设置属性display:none;如 , 这样就有了真正的上传文件的地方了。所以,可以说,上传文件的界面有多漂亮取决你的想象力!2. 怎样触发事件?

这是个重点,触发的点应该是自己写的样式处,而真正起作用的元素却是隐藏的,但是并不影响它的点击效果,只需要给它触发一个点击事件即可,如$('#target-file').trigger('click');3. 多选文件?

多文件上传,只需使用html的一个file的multiple=true即可,当然你也可以选择第三方的上传控件,如swfupload,效果是真心不错的,但是对于不想用的插件的人,就不起作用了。                                                                          4.  相关插件? 

界面美化其实可以使用jqueryui等插件;

要做一些友好的交互的话,都会用到ajax技术,无刷新切换、异步上传、提交,最后,其实ajax的路径也是可以保留的,使用pushState, replaceState 实现 pjax .

表单验证:validform.js

异步提交文件: jquery.form.js

友好的弹窗提示:layer.js

5. 一点兼容性的问题?

做界面方面的工作,最怕的也是很重要的工作,就是各个浏览器之间的兼容性问题,下面主要列几点供参考:

table宽度的处理方式不一致;

select, input显示高度不一致;

alert弹窗不一致;

...

6. 演示代码?

<a href="javascript:;" up-type-id="1" class="btn btn-default small-btn switch-upload-method"><span>本地上传</span></a><a href="javascript:;" up-type-id="2" class="upload-file-instead btn btn-default small-btn switch-upload-method"><span>打包工具</span></a><input type="file" name="apkFiles[]" id="local-upload-real-file" class="upload-file-real hide" response-id="local-upload-container" multiple='true'  /><input type="file" name="apkToolFiles[]" id="apk-tool-real-file" class="upload-file-real hide" response-id="apk-tool-container-textarea" /><script>    $(function(){        var alertTitle = '系统提示:';        var submitId = '#do-submit';        $('#taskForm').Validform({            btnSubmit: submitId,            tiptype: 1,            ignoreHidden: true,            dragonfly: false,            tipSweep: true,            label: ".label",            showAllError: false,            postonce: true,            ajaxPost: true,            datatype:{            },            beforeCheck:function(curform){            },            beforeSubmit:function(curform){                $('.upload-file-real').attr('disabled', 'disabled');                $(submitId).attr('disabled', 'disabled');   //提交前禁用按钮                ajaxSubmitForm(curform);                $(submitId).removeAttr('disabled');         //失败后恢复可提交                return false;            },            submitForm: function(){}                        //不再起作用        });        //切换上传方法        $('.switch-upload-method').off().on('click', function(){//            $(submitId).attr('disabled', 'disabled');            var pObj = $(this).parent().find('.switch-upload-method');            var index = pObj.index(this);            var uploadTypeId = $('#upload-type-id').val();                      //上传方式:1:打包工具;2:本地上传,0:没有上传方式            var uploadType = $(this).attr('up-type-id');            if(parseInt($('#sub-channel-count').html()) > 0){                if(uploadTypeId != uploadType){                    layer.alert('还有子渠道包数据,不能完成切换,请先确认清除再切换!');                    return false;                }            }            pObj.not(':eq(' + index + ')').removeClass('btn-danger').addClass('btn-default');            pObj.eq(index).removeClass('btn-default').addClass('btn-danger');            if(uploadType == 36){               //local-upload                $('#upload-type-id').val(uploadType);                $('#init-apk-container').show();                $('#apk-tool-container').hide();                $('#upload-main-control').find('.del-it-main').css({display: 'inline-block'});                $('#local-upload-real-file').trigger('click');            }else if(uploadType == 35){         //apk-tool                $('#upload-type-id').val(uploadType);                $('#init-apk-container').hide();                $('#local-upload-container').hide();                $('#upload-main-control').find('.del-it-main').hide();                $('#apk-tool-container').show();            }        });        //本地上传        $('#local-upload-real-file').off().on('change', function(){            if(!$(this).val()){                return false;            }            file_size = 0;            filepath = $(this).val();            maxFileSize = 30 * 1024 * 1024;            var  browserCfg = {};            var ua = window.navigator.userAgent;            if (ua.indexOf("MSIE") >=1 ){                browserCfg.ie = true;            }else if(ua.indexOf("Firefox") >=1 ){                browserCfg.firefox = true;            }else if(ua.indexOf("Chrome") >=1 ){                browserCfg.chrome = true;            }            if (browserCfg.ie) {                var img = new Image();                img.src = filepath;                file_size = img.fileSize;                while (true) {                    if (img.fileSize > 0) {                        if (img.fileSize > maxFileSize) {                            alert("上传包超过30MB限制,请使用打包工具上传!");                            return false;                        }                        break;                    }                }            } else {                file_size = this.files[0].size;                if (file_size > maxFileSize) {                    alert("上传包超过30MB限制,请使用打包工具上传!");                    return false;                }            }            var responseObjId = $(this).attr('response-id');            var responseObj = $('#' + responseObjId);            $('#taskForm').ajaxSubmit({                url:'/aa/bb/uploadTmpApk',                resetForm: false,                dataType:  'json',                beforeSubmit:  function(option){                    window.loading = layer.load(2);                },                success: function(data, statusText){                    layer.close(window.loading);                    if(data.status == 1){                        $('#version-identifier').val(data.version);                        responseObj.html(data.apkInfoHtml);                        responseObj.show();                        var delObj = $('#upload-main-control').find('.del-it-main');                        delObj.css({'display': 'inline-block'});                        $('#sub-channel-count').html(data.apkTotal);                        $('#init-apk-container').hide();                        $(submitId).removeAttr('disabled');                    }else{                        layer.alert(data.info, {title: alertTitle});                    }                },                error: function(data){                    layer.close(window.loading);                    layer.alert('未知错误,请稍后再试!');                }            });            return false;//防止dialog 自动关闭        });        //打包工具        $('#apk-tool-real-file').off().on('change', function(){            if(!$(this).val()){                return false;            }            var responseObjId = $(this).attr('response-id');            var responseObj = $('#' + responseObjId);            $('#Form').ajaxSubmit({                url:'/aa/bb/uploadTmpApkTool',                resetForm: false,                dataType:  'json',                beforeSubmit:  function(option){                    window.loading = layer.load(2);                },                success: function(data, statusText){                    layer.close(window.loading);                    if(data.status == 1){                        $('#version-identifier').val(data.version);                        responseObj.html(data.infoHtml);                        var parentContainer = responseObj.parent().parent(),                            nameContainer = parentContainer.find('.apk-name-container'),                                delObj = parentContainer.find('.del-it-apk-tool');                        nameContainer.html(data.apkName);                        nameContainer.attr('title', data.apkName);                        $('#apk-tool-file-tmp').html(data.fileInfo);                        $(submitId).removeAttr('disabled');                    }else{                        layer.alert(data.info, {title: alertTitle});                    }                },                error: function(data){                    layer.close(window.loading);                    layer.alert('未知错误,请稍后再试!');                }            });            return false;//防止dialog 自动关闭        });        $('.apk-tool-upload-button').on('click', function(){            $('#apk-tool-real-file').trigger('click');        });    });</script>
登录后复制

以上,主要就是,使用隐藏的input file标签选择,选择文件之后立即ajax提交,最后,整个表单ajax提交的过程。

合理使用一些css, js, 让你的网页更自由!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验? 公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验? Mar 04, 2025 pm 12:32 PM

公众号网页更新缓存,这玩意儿,说简单也简单,说复杂也够你喝一壶的。你辛辛苦苦更新了公众号文章,结果用户打开还是老版本,这滋味,谁受得了?这篇文章,咱就来扒一扒这背后的弯弯绕绕,以及如何优雅地解决这个问题。读完之后,你就能轻松应对各种缓存难题,让你的用户始终体验到最新鲜的内容。先说点基础的。网页缓存,说白了就是浏览器或者服务器为了提高访问速度,把一些静态资源(比如图片、CSS、JS)或者页面内容存储起来。下次访问时,直接从缓存里取,不用再重新下载,速度自然快。但这玩意儿,也是个双刃剑。新版本上线,

如何使用HTML5表单验证属性来验证用户输入? 如何使用HTML5表单验证属性来验证用户输入? Mar 17, 2025 pm 12:27 PM

本文讨论了使用HTML5表单验证属性,例如必需的,图案,最小,最大和长度限制,以直接在浏览器中验证用户输入。

HTML5中跨浏览器兼容性的最佳实践是什么? HTML5中跨浏览器兼容性的最佳实践是什么? Mar 17, 2025 pm 12:20 PM

文章讨论了确保HTML5跨浏览器兼容性的最佳实践,重点是特征检测,进行性增强和测试方法。

如何高效地在网页中为PNG图片添加描边效果? 如何高效地在网页中为PNG图片添加描边效果? Mar 04, 2025 pm 02:39 PM

本文展示了使用CSS为网页中添加有效的PNG边框。 它认为,与JavaScript或库相比,CSS提供了出色的性能,详细介绍了如何调整边界宽度,样式和颜色以获得微妙或突出的效果

&lt; datalist&gt;的目的是什么。 元素? &lt; datalist&gt;的目的是什么。 元素? Mar 21, 2025 pm 12:33 PM

本文讨论了html&lt; datalist&gt;元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

&gt; gt;的目的是什么 元素? &gt; gt;的目的是什么 元素? Mar 21, 2025 pm 12:34 PM

本文讨论了HTML&lt; Progress&gt;元素,其目的,样式和与&lt; meter&gt;元素。主要重点是使用&lt; progress&gt;为了完成任务和LT;仪表&gt;对于stati

我如何使用html5&lt; time&gt; 元素以语义表示日期和时间? 我如何使用html5&lt; time&gt; 元素以语义表示日期和时间? Mar 12, 2025 pm 04:05 PM

本文解释了HTML5&lt; time&gt;语义日期/时间表示的元素。 它强调了DateTime属性对机器可读性(ISO 8601格式)的重要性,并在人类可读文本旁边,增强Accessibilit

&lt; meter&gt;的目的是什么。 元素? &lt; meter&gt;的目的是什么。 元素? Mar 21, 2025 pm 12:35 PM

本文讨论了HTML&lt; meter&gt;元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了&lt; meter&gt;从&lt; progress&gt;和前

See all articles