JavaScript獲取元素透明度

admin發表於2017-04-05

本章節介紹一下如何利用JavaScript動態獲取元素透明度。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼執行程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style>
*{
  margin:0px;
  padding:0px;
}
#antzone{
  width:200px;
  height:100px;
  text-align:center;
  line-height:100px;
  background:#CCC;
  opacity:0.3;
  filter:alpha(opacity=30);
}
</style>
<script type="text/javascript">
function getstyle(obj,name){
  if(obj.currentStyle){
    return obj.currentStyle[name];
  }
  else{
    return getComputedStyle(obj,false)[name];
  }
}
window.onload=function(){
  var obt=document.getElementById("bt");
  var odiv=document.getElementById("antzone");
  obt.onclick=function(){
    odiv.innerHTML=getstyle(odiv,"opacity");
  }
}
</script>
</head>
<body>
<div id="antzone"></div>
<input type="button" id="bt" value="檢視效果"/>
</body>
</html>

上面的程式碼實現了獲取元素透明度的效果,並且能夠相容各個瀏覽器。

低版本的IE瀏覽器下,設定透明度需要使用filter:alpha(opacity=30)方式,但在獲取透明度的時候卻是非常類似於標準瀏覽器,直接使用currentStyle["opacity"]即可獲取,並且獲取的值也是0-1之間。

相關文章