首頁  >  文章  >  web前端  >  JS運動改變單物體透明度的方法分析

JS運動改變單物體透明度的方法分析

韦小宝
韦小宝原創
2018-01-24 09:56:461356瀏覽

這篇文章主要介紹了JS運動改變單物體透明度的方法,結合實例形式分析了頁面元素屬性動態修改相關JS操作技巧,對JavaScript感興趣的朋友可以參考下本篇文章

除了透過改變物體的寬,高,letf,top位置或是運動方向來實現物體運動效果之外,改變物體的透明度,也是運動特效

<script>
  window.onload = function () {
    var op = document.getElementById(&#39;p1&#39;);
    op.onmousemove = function () {
      startMove(100);
    }
    op.onmouseout = function () {
      startMove(30);
    }
}
var timer = null;
function startMove(iTarget) {
    clearInterval(timer);
    var op = document.getElementById(&#39;p1&#39;);
    timer = setInterval(function(){
      if(op.offsetAlpha == iTarget){
        ....
      }
    },30);
}
</script>

但是在js中只有offsetLeft/Top ,offsetWidth/Height,這四個方法,並沒有offsetAlpha這個方法。

問:那我們怎麼來 取得目前物體的透明度那? ?

我們可以自己定義一個變數var alpha  = 30;透過判斷這個變數是否和目標值是否相等,來繼續我們下一步的操作;

var alpha = 30; // 自定义一个变量

當alpha 等目標值得時候,清楚計時器,否則就改變透明度的值alpha

if(alpha == iTarget){
   clearInterval(timer);
}else{
   alpha += iSpeed;
   op.style.opacity = alpha/100;
   op.style.filter = &#39;alpha(opacity:&#39;+alpha+&#39;)&#39;;
}

完整的程式碼如下:

<p id="p1"></p>

css樣式部分:

<style>
    #p1{
      width: 100px;height: 100px;
      background: green;
      opacity:0.3;
      filter:alpha(opacity:30);/*兼容低版本IE*/
    }
</style>

js部分:

<script>
  window.onload = function () {
    var op = document.getElementById(&#39;p1&#39;);
    op.onmousemove = function () {
      startMove(100);
    }
    op.onmouseout = function () {
      startMove(30);
    }
  }
  var timer = null;
  var alpha = 30;
  function startMove(iTarget) {
    clearInterval(timer);
    var op = document.getElementById(&#39;p1&#39;);
    var iSpeed = 0;
    timer = setInterval(function(){
      if(alpha>iTarget){
        iSpeed = -10;
      }else{
        iSpeed = 10;
      }
      if(alpha == iTarget){
        clearInterval(timer);
      }else{
        alpha += iSpeed;
        op.style.opacity = alpha/100;
        op.style.filter = &#39;alpha(opacity:&#39;+alpha+&#39;)&#39;;
      }
    },30);
  }
</script>

以上就是本篇文章的所有內容,希望對大家學習提供到幫助! !

相關推薦:

js封裝成外掛_Canvas統計圖外掛程式編寫實例

html、css、javascript實作樓層跳躍式的頁面佈局

JavaScript模組模式詳解

#

以上是JS運動改變單物體透明度的方法分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn