首頁 > web前端 > js教程 > 主體

JS運動改變單物體透明度實現方法

小云云
發布: 2018-01-24 09:06:06
原創
1153 人瀏覽過

本文主要介紹了JS運動改變單物體透明度的方法,結合實例形式分析了頁面元素屬性動態修改相關操作技巧,需要的朋友可以參考下,希望能幫助到大家

#除了通過改變物體的寬,高,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>
登入後複製

相關推薦;

css怎麼設定透明度

使用JQUERY實現可變透明度返回頂部效果

實現CSS3不透明度完整程式碼

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!