<input type="file">實現各個瀏覽器樣式統一程式碼例項

admin發表於2017-03-28

很多朋友可能遇到過這樣的問題,那就是<input type="file">檔案在各個瀏覽器中的外觀差距會很大,就算是沒有差距的話,外觀也實在醜的無法想象,下面就通過程式碼例項詳細介紹一下如何實現此控制元件的表現能夠在各個瀏覽器都統一,並且進行簡單的美化。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
body{
  font-size:14px;
}
input{
  vertical-align:middle;
  margin:0;
  padding:0
}
.file-box{
  position:relative;
  width:340px
}
.txt{
  height:22px;
  border:1px solid #cdcdcd;
  width:180px;
}
.btn{
  background-color:#FFF;
  border:1px solid #CDCDCD;
  height:24px;
  width:70px;
}
.file{
  position:absolute;
  top:0;
  right:80px;
  height:24px;
  filter:alpha(opacity:0);
  opacity: 0;
  width:260px
}
</style>
<script type="text/javascript">
window.onload=function(){
  var otextfield=document.getElementById("textfield");
  var ofileField=document.getElementById("fileField");
  ofileField.onchange=function(){
    otextfield.value=this.value;
  }
}
</script>
</head>
<body>
<div class="file-box">
  <form action="" method="post" enctype="multipart/form-data">
    <input type='text' name='textfield' id='textfield' class='txt'/>
    <input type='button' class='btn' value='瀏覽...'/>
    <input type="file" name="fileField" class="file" id="fileField" size="28"/>
    <input type="submit" name="submit" class="btn" value="上傳" />
  </form>
</div>
</body>
</html>

上面的程式碼基本實現了我們的要求,下面介紹一下它的實現過程。

實現原理:

原理實際上非常的簡單,我們用肉眼看到的是一個文字框加兩個按鈕,只不過第一個按鈕的值設定為"瀏覽..",這樣給人一種檔案上傳空間的錯覺。而真正的檔案上傳控制元件是透明的,採用絕對定位的方式覆蓋於文字框和第一個按鈕之上,這樣點選文字框或者按鈕都是點選的上傳控制元件,然後再將上傳控制元件的value值賦值給文字框,這樣就模擬實現了我們想要的效果。

相關文章