bootstrap中好看的文件上传样式

来源:互联网 发布:寻路中国知乎 编辑:程序博客网 时间:2024/04/30 21:12

一 直接使用bootstrap,利用简单的js控制

http://duckranger.com/2012/06/pretty-file-input-field-in-bootstrap/

非常简单,代码如下:

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. <input id="lefile" type="file" style="display:none">  
  2. <div class="input-append">  
  3.     <input id="photoCover" class="input-large" type="text" style="height:30px;">  
  4.     <a class="btn" onclick="$('input[id=lefile]').click();">Browse</a>  
  5. </div>  
  6.    
  7. <script type="text/javascript">  
  8. $('input[id=lefile]').change(function() {  
  9. $('#photoCover').val($(this).val());  
  10. });  
  11. </script>  

效果如下:


不需要任何其他的js和css,只需要引入bootstrap和jQuery即可

其实这个就是拼接出来的,然后js控制显示文件名。

效果如下:



二  bootstrap-filestyle

http://markusslima.github.io/bootstrap-filestyle/


注意:此样式只能使用bootstrap2的css,版本为bootstrap3的css是不兼容的!!(妈蛋我就因为这个测试了老半天。。摔

效果如下:




三 bootstrap-file-input

http://www.gregpike.net/demos/bootstrap-file-input/demo.html

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3.     <head>  
  4.         <meta charset="utf-8">  
  5.         <title>bootstrap.file-input</title>  
  6.   
  7.         <link href="css/bootstrap.min.css" rel="stylesheet" />  
  8.   
  9.         <script type="text/javascript" src="js/jquery-2.0.3.min.js"></script>  
  10.         <script type="text/javascript" src="js/bootstrap.min.js"></script>  
  11.         <script type="text/javascript" src="js/bootstrap.file-input.js"></script>  
  12.       
  13.     </head>  
  14.   
  15.     <body>  
  16.         <!-- Change the wording using a title tag -->  
  17.         <input type="file" title="Search for a file to add 1" class="btn-primary">  
  18.         <br>  
  19.         <br>  
  20.         <input type="file" title="Search for a file to add 2" class="btn btn-primary">  
  21.         <br>  
  22.         <br>  
  23.         <input type="file" title="Search for a file to add 3" class="btn-primary">  
  24.         <br>  
  25.         <br>  
  26.         <input type="file" title="Search for a file to add 4" class="btn-primary">  
  27.         <br>  
  28.         <br>  
  29.         <br>  
  30.         <br>  
  31.         <br>  
  32.         Disable the styling:  
  33.           
  34.         <!-- Disable the styling -->  
  35.         <input type="file" data-bfi-disabled>  
  36.         <script type="text/javascript">  
  37.             $('input[type=file]').bootstrapFileInput();  
  38.               
  39.         </script>  
  40.     </body>  
  41. </html>  

引入了bootstrap.file-input.js但是直接引入有点小问题,说找不到bootstrapFileInput这个方法。于是我就改了一点js:

[javascript] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. /* 
  2.   Bootstrap - File Input 
  3.   ====================== 
  4.  
  5.   This is meant to convert all file input tags into a set of elements that displays consistently in all browsers. 
  6.  
  7.   Converts all 
  8.   <input type="file"> 
  9.   into Bootstrap buttons 
  10.   <a class="btn">Browse</a> 
  11.  
  12. */  
  13.   
  14.   
  15. $.fn.bootstrapFileInput = function() {  
  16.   
  17. 这里我直接用这个方法,把前面一行删掉就可以了  
  18.   
  19.   this.each(function(i,elem){  
  20.   
  21. .........中间省略  
  22.     
  23. // Add the styles before the first stylesheet  
  24. // This ensures they can be easily overridden with developer styles  
  25. var cssHtml = '<style>'+  
  26.   '.file-input-wrapper { overflow: hidden; position: relative; cursor: pointer; z-index: 1; }'+  
  27.   '.file-input-wrapper input[type=file], .file-input-wrapper input[type=file]:focus, .file-input-wrapper input[type=file]:hover { position: absolute; top: 0; left: 0; cursor: pointer; opacity: 0; filter: alpha(opacity=0); z-index: 99; outline: 0; }'+  
  28.   '.file-input-name { margin-left: 8px; }'+  
  29.   '</style>';  
  30. $('link[rel=stylesheet]').eq(0).before(cssHtml);  
  31.   
  32. };  

好了,到了看效果的时候啦~~




四  Fine Uploader

http://fineuploader.com/demos.html

在官网下载是收费的。。我在github下载了一个。

下载链接

下载解压后是这样的:

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3.     <head>  
  4.         <meta charset="utf-8">  
  5.         <title>bootstrap.file-input</title>  
  6.   
  7.         <link href="css/bootstrap.min.css" rel="stylesheet" />  
  8.         <link href="css/fineuploader.css" rel="stylesheet" />  
  9.   
  10.         <script type="text/javascript" src="js/jquery-2.0.3.min.js"></script>  
  11.         <script type="text/javascript" src="js/bootstrap.min.js"></script>  
  12.         <script type="text/javascript" src="js/all.fineuploader-4.3.1.min.js"></script>  
  13.       
  14.     </head>  
  15.   
  16.     <body>          
  17.         <br>  
  18.         <div id="manual-fine-uploader"></div>  
  19.         <div id="triggerUpload" class="btn btn-primary" style="margin-top: 10px;">  
  20.           <i class="icon-upload icon-white"></i> Upload now  
  21.         </div>  
  22.         <script>  
  23.           $(document).ready(function() {  
  24.             var manualuploader = $('#manual-fine-uploader').fineUploader({  
  25.               request: {  
  26.                 endpoint: 'server/handleUploads'  
  27.               },  
  28.               autoUpload: false,  
  29.               text: {  
  30.                 uploadButton: '<i class="icon-plus icon-white"></i> Select Files'  
  31.               }  
  32.             });  
  33.            
  34.             $('#triggerUpload').click(function() {  
  35.               manualuploader.fineUploader('uploadStoredFiles');  
  36.             });  
  37.           });  
  38.         </script>  
  39.   
  40.       
  41.   
  42.   
  43.         <script>  
  44.           $(document).ready(function () {  
  45.             $('#fine-uploader').fineUploader({  
  46.               request: {  
  47.                 endpoint: 'server/handleUploads'  
  48.               }  
  49.             });  
  50.           });  
  51.         </script>  
  52.   
  53.         <!-- Fine Uploader CSS  
  54.         ====================================================================== -->  
  55.   
  56.   
  57.         <!-- Fine Uploader DOM Element  
  58.         ====================================================================== -->  
  59.         <div id="fine-uploader"></div>  
  60.   
  61.         <!-- Fine Uploader template  
  62.         ====================================================================== -->  
  63.         <script type="text/template" id="qq-template">  
  64.           <div class="qq-uploader-selector qq-uploader">  
  65.             <div class="qq-upload-drop-area-selector qq-upload-drop-area" qq-hide-dropzone>  
  66.               <span>Drop files here to upload</span>  
  67.             </div>  
  68.             <div class="qq-upload-button-selector qq-upload-button">  
  69.               <div>Upload a file</div>  
  70.             </div>  
  71.             <span class="qq-drop-processing-selector qq-drop-processing">  
  72.               <span>Processing dropped files...</span>  
  73.               <span class="qq-drop-processing-spinner-selector qq-drop-processing-spinner"></span>  
  74.             </span>  
  75.             <ul class="qq-upload-list-selector qq-upload-list">  
  76.               <li>  
  77.                 <div class="qq-progress-bar-container-selector">  
  78.                   <div class="qq-progress-bar-selector qq-progress-bar"></div>  
  79.                 </div>  
  80.                 <span class="qq-upload-spinner-selector qq-upload-spinner"></span>  
  81.                 <span class="qq-edit-filename-icon-selector qq-edit-filename-icon"></span>  
  82.                 <span class="qq-upload-file-selector qq-upload-file"></span>  
  83.                 <input class="qq-edit-filename-selector qq-edit-filename" tabindex="0" type="text">  
  84.                 <span class="qq-upload-size-selector qq-upload-size"></span>  
  85.                 <a class="qq-upload-cancel-selector qq-upload-cancel" href="#">Cancel</a>  
  86.                 <a class="qq-upload-retry-selector qq-upload-retry" href="#">Retry</a>  
  87.                 <a class="qq-upload-delete-selector qq-upload-delete" href="#">Delete</a>  
  88.                 <span class="qq-upload-status-text-selector qq-upload-status-text"></span>  
  89.               </li>  
  90.             </ul>  
  91.           </div>  
  92.         </script>  
  93.     </body>  
  94. </html>  
js和css,你们在文件夹里搜索就能找到,但是有一个all.fineuploader-4.3.1.min.js,是我在官网用chrome审查元素copy下来的。。经测试可以用

注意中间代码中的Template

如果没有这一段,console将会报错:


然后我查到一个原因:

大家可以阅读下,就是必须要有一个模板文件才可以运行。


效果如下:(没导css对应的图片有点丑)


五  其他


http://www.cnblogs.com/lhb25/p/form-enhanced-with-javascript-five.html

这个网页里还推荐了其他几款比较不错的。

jQuery File Uploader

DropZoneJS

Uploadify

FineUploader


0 0
原创粉丝点击