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 相关文章推荐
IE6/7 and IE8/9/10(IE7模式)依次隐藏具有absolute或relative的父元素和子元素后再显示父元素
Jul 31 Javascript
jquery select多选框的左右移动 具体实现代码
Jul 03 Javascript
html5+javascript制作简易画板附图
Apr 25 Javascript
你所不了解的javascript操作DOM的细节知识点(一)
Jun 17 Javascript
AngularJS动态加载模块和依赖的方法分析
Nov 08 Javascript
jQuery中用on绑定事件时需注意的事项
Mar 19 Javascript
JavaScript之RegExp_动力节点Java学院整理
Jun 29 Javascript
Angular中的$watch方法详解
Sep 18 Javascript
js实现QQ面板拖拽效果(慕课网DOM事件探秘)(全)
Sep 19 Javascript
TypeScript基础入门教程之三重斜线指令详解
Oct 22 Javascript
vue 实现Web端的定位功能 获取经纬度
Aug 08 Javascript
JavaScript中reduce()的5个基本用法示例
Jul 19 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
php 字符转义 注意事项
2009/05/27 PHP
PHP读取XML值的代码(推荐)
2011/01/01 PHP
PHPThumb PHP 图片缩略图库
2012/03/11 PHP
php中使用base HTTP验证的方法
2015/04/20 PHP
php 批量查询搜狗sogou代码分享
2015/05/17 PHP
Zend Framework教程之前端控制器Zend_Controller_Front用法详解
2016/03/07 PHP
FleaPHP框架数据库查询条件($conditions)写法总结
2016/03/19 PHP
PHP两种实现无级递归分类的方法
2017/03/02 PHP
使用PHP json_decode可能遇到的坑与解决方法
2017/08/03 PHP
PHP实现的杨辉三角求解算法分析
2019/03/11 PHP
jquery插件制作教程 txtHover
2012/08/17 Javascript
replace()方法查找字符使用示例
2013/10/28 Javascript
js数组操作学习总结
2013/11/04 Javascript
javascript history对象(历史记录)使用方法(实现浏览器前进后退)
2014/01/07 Javascript
JQuery 在线引用及测试引用是否成功
2014/06/24 Javascript
jQuery对val和atrr(&quot;value&quot;)赋值的区别介绍
2014/09/26 Javascript
JavaScript中的闭包
2016/02/24 Javascript
Javascript HTML5 Canvas实现的一个画板
2020/04/12 Javascript
BootStrap入门教程(三)之响应式原理
2016/09/19 Javascript
webpack入门+react环境配置
2017/02/08 Javascript
详解vue渲染从后台获取的json数据
2017/07/06 Javascript
vue-router二级导航切换路由及高亮显示的实现方法
2019/07/10 Javascript
解决vue项目刷新后,导航菜单高亮显示的位置不对问题
2019/11/01 Javascript
Vue中computed及watch区别实例解析
2020/08/01 Javascript
Python深入06——python的内存管理详解
2016/12/07 Python
python web自制框架之接受url传递过来的参数实例
2018/12/17 Python
python读取目录下最新的文件夹方法
2018/12/24 Python
python利用Tesseract识别验证码的方法示例
2019/01/21 Python
pytorch 自定义参数不更新方式
2020/01/06 Python
Python自动化测试笔试面试题精选
2020/03/12 Python
解决django的template中如果无法引用MEDIA_URL问题
2020/04/07 Python
python装饰器实现对异常代码出现进行自动监控的实现方法
2020/09/15 Python
俄罗斯游戏商店:Buka
2020/03/01 全球购物
linux面试题参考答案(6)
2016/06/23 面试题
四种会话跟踪技术
2015/05/20 面试题
产品生产计划书
2014/05/07 职场文书