background image

<div 

class

="progress"> 

<span 

class

="bar"></span><span 

class

="percent">0%</span > 

</div> 
<div 

class

="files"></div> 

<div id="showimg"></div> 
 
我们在 html 中放置一个添加附件的按钮元素.btn,以及进度条.progress,用于显示文件信
息的.files 和显示图片的#showimg
可以看出,我们用于上传文件的 html 中并没有出现 form 表单,而正常的上传功能是要依
赖 form 表单的。我们的 form 表单是动态插入的,这样可以避免一个大表单中出现多个
form。

CSS

我们使用 css 可以将传统的浏览文件的表单控件美化成一个按钮,这样看起来是不是很酷。

 
代码如下:
 
.btn{position: relative;overflow: hidden;margin-right: 4px;display:inline-block; 
*display:inline;padding:4px 10px 4px;font-size:14px;line-height:18px; 
*line-height:20px;color:#fff; 
text-align:center;vertical-align:middle;cursor:pointer;background:#5bb75b; 
border:1px solid #cccccc;border-color:#e6e6e6 #e6e6e6 #bfbfbf; 
border-bottom-color:#b3b3b3;-webkit-border-radius:4px; 
-moz-border-radius:4px;border-radius:4px;} 
.btn input{position: absolute;top: 0; right: 0;margin: 0;border:solid transparent; 
opacity: 0;filter:alpha(opacity=0); cursor: pointer;} 
.progress{position:relative; margin-left:100px; margin-top:-24px; 
width:200px;padding: 1px; border-radius:3px; display:none} 
.bar {background-color: green; display:block; width:0%; height:20px; 
border-radius:3px; } 
.percent{position:absolute; height:20px; display:inline-block; 
top:3px; left:2%; color:#fff } 
.files{height:22px; line-height:22px; margin:10px 0} 
.delimg{margin-left:20px; color:#090; cursor:pointer} 
 
jQuery
首先定义各种变量,注意动态将表单元素 form 插入到上传按钮部位,并且 form 的属性
enctype 必须设置为:multipart/form- data

。然后当点击 上传附件 按钮,选择要上传的文

件后,调用 jquery.form 插件的 ajaxSubmit 方法,如下代码说明。