JS运动改变单物体透明度的方法分析


Posted in Javascript onJanuary 23, 2018

本文实例讲述了JS运动改变单物体透明度的方法。分享给大家供大家参考,具体如下:

除了通过改变物体的 宽,高,letf,top位置或者是运动方向来实现物体运动效果之外,改变物体的透明度,也是运动特效

<script>
  window.onload = function () {
    var oDiv = document.getElementById('div1');
    oDiv.onmousemove = function () {
      startMove(100);
    }
    oDiv.onmouseout = function () {
      startMove(30);
    }
}
var timer = null;
function startMove(iTarget) {
    clearInterval(timer);
    var oDiv = document.getElementById('div1');
    timer = setInterval(function(){
      if(oDiv.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;
   oDiv.style.opacity = alpha/100;
   oDiv.style.filter = 'alpha(opacity:'+alpha+')';
}

完整的代码如下:

<div id="div1"></div>

css样式部分:

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

js部分:

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

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jQuery Ajax之load()方法
Oct 12 Javascript
Javascript 类与静态类的实现
Apr 01 Javascript
javascript 主动派发事件总结
Aug 09 Javascript
基于jquery的web页面日期格式化插件
Nov 15 Javascript
封装了一个支持匿名函数的Javascript事件监听器
Jun 05 Javascript
JavaScript字符串对象toUpperCase方法入门实例(用于把字母转换为大写)
Oct 17 Javascript
使用ajax+jqtransform实现动态加载select
Dec 01 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
Apr 19 Javascript
微信小程序实现滑动删除效果
May 19 Javascript
Bootstrap实现的表格合并单元格示例
Feb 06 Javascript
JavaScript强制类型转换和隐式类型转换操作示例
May 01 Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
Oct 14 Javascript
JS实现基于拖拽改变物体大小的方法
Jan 23 #Javascript
基于vue cli重构多页面脚手架过程详解
Jan 23 #Javascript
JS实现点击下拉菜单把选择的内容同步到input输入框内的实例
Jan 23 #Javascript
实时监控input框,实现输入框与下拉框联动的实例
Jan 23 #Javascript
从parcel.js打包出错到选择nvm的全部过程
Jan 23 #Javascript
浅谈vue项目重构技术要点和总结
Jan 23 #Javascript
bootstrap fileinput插件实现预览上传照片功能
Jan 23 #Javascript
You might like
MySQL连接数超过限制的解决方法
2011/07/17 PHP
PHP实现图片压缩的两则实例
2014/07/19 PHP
php广告加载类用法实例
2014/09/23 PHP
PHP 双链表(SplDoublyLinkedList)简介和使用实例
2015/05/12 PHP
Smarty简单生成表单元素的方法示例
2016/05/23 PHP
PHP fclose函数用法总结
2019/02/15 PHP
javascript 防止刷新,后退,关闭
2010/08/07 Javascript
jQuery.each()用法分享
2012/07/31 Javascript
JavaScript新窗口与子窗口传值详解
2014/02/11 Javascript
Javascript URI 解析介绍
2015/03/15 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【二】
2016/05/10 Javascript
详解JavaScript中双等号引起的隐性类型转换
2016/05/30 Javascript
JS前端加密算法示例
2016/12/22 Javascript
原生js实现焦点轮播图效果
2017/01/12 Javascript
在vue中v-bind使用三目运算符绑定class的实例
2018/09/29 Javascript
vue+axios+promise实际开发用法详解
2018/10/15 Javascript
基于vue如何发布一个npm包的方法步骤
2019/05/15 Javascript
ES6基础之 Promise 对象用法实例详解
2019/08/22 Javascript
Node.js安装详细步骤教程(Windows版)详解
2019/09/01 Javascript
vue 限制input只能输入正数的操作
2020/08/05 Javascript
[01:05:56]Liquid vs VP Supermajor决赛 BO 第二场 6.10
2018/07/04 DOTA
使用Python编写一个简单的tic-tac-toe游戏的教程
2015/04/16 Python
Python中selenium实现文件上传所有方法整理总结
2017/04/01 Python
Python爬虫包BeautifulSoup异常处理(二)
2018/06/17 Python
Python 打印中文字符的三种方法
2018/08/14 Python
Python OS模块实例详解
2019/04/15 Python
django基于restframework的CBV封装详解
2019/08/08 Python
Python实现网页截图(PyQT5)过程解析
2019/08/12 Python
python爬虫 猫眼电影和电影天堂数据csv和mysql存储过程解析
2019/09/05 Python
django模板获取list中指定索引的值方式
2020/05/14 Python
Parts Express:音频、视频和扬声器的第一来源
2017/04/25 全球购物
主治医师岗位职责
2013/12/10 职场文书
机电一体化应届生求职信范文
2014/01/24 职场文书
安全生产责任书范本
2014/04/15 职场文书
《放飞蜻蜓》教学反思
2014/04/27 职场文书
2015年导购员工作总结
2015/04/25 职场文书