下面是file上传控件在IE10,firefox16,chrome22,opera12,safari5.1.7里的截图:
 
在IE10里,双击输入框或者单击按钮都弹出文件选择框。在其他浏览器里单击输入框,按钮或文字都可以触发文件选择框。 
鉴于这种混乱情况,有必要要统一样式和行为。下面是我的兼容性方案。 
先看一下最终结果在各浏览器的截图: 

基本思路:创建输入框和按钮模拟file上传控件。将file上传控件设置成透明。让file上传控件与用于模拟的按钮右对齐。修改元素的堆叠顺序,让按钮处于下面,file上传控件在中间,输入框在上面。在文件选择完毕后将file上传控件里的值赋给用于模拟的输入框。 
原理:在不同的浏览器里,file上传控件的按钮的height都是可调的,而且file上传控件的右侧都是可以单击的。所以通过调节file上传控件的height,并调整file上传控件的位置(右对齐),可以让file上传控件的可单击区域与用于模拟的按钮完全覆盖。当file上传控件透明时用户单击用于模拟的按钮就触发了文件选择框。但同时file上传控件的堆叠顺序不能先于用于模拟的输入框,不然当用户将鼠标置于所见的输入框上时可能会看到光标不是指示文本而是为一个箭头(而且为一个箭头时单击会弹出文件选择框),用户将感到困惑。 
实现:先看看html部分的代码。 
复制代码代码如下: 
<div id="file"> 
<input type="text" value="未选择文件" /><input type="button" value="浏览" /><input type="file" /> 
</div> 
然后是css部分的代码。 
复制代码代码如下: 
#file { 
position:relative; 
width:226px; 
height:25px; 
border:1px #99f solid; 
} 
#file input { 
font-size:16px; 
margin:0; 
padding:0; 
position:relative; 
vertical-align:middle; 
outline:none; 
} 
#file input[type="text"] { 
border:3px none; 
width:172px; 
z-index:4; 
} 
#file input[type="button"] { 
width:54px; 
height:25px; 
z-index:2; 
} 
#file input[type="file"] { 
position:absolute; 
right:0px; 
height:25px; 
opacity:0; 
z-index:3; 
} 
最后javascript部分,用于把file上传控件获得的文件路径显示到可见的输入框里。 
复制代码代码如下: 
window.onload=function(){ 
var file=document.querySelector("#file input[type='file']"); 
var text=document.querySelector("#file input[type='text']"); 
file.addEventListener("change",assign,false); 
function assign(){ 
text.value=file.value; 
} 
} 
欢迎留言交流或指正。
样式,浏览器
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
                        


