zoukankan      html  css  js  c++  java
  • JavaScript——创建运动框架

    封装好的运动框架Move(obj,attr,iTarget),可直接调用:

    可用于设置width、border、fontSize、marginLeft、opacity等许多常见属性值的变速变化,实现各种有趣效果。

    兼容IE和FF。

    /****************
        *
        *   IE-BUG:
        *   在IE中,设置opacity属性时,元素样式中需要设置opacity属性,才能读取到opacity值。
        *
        *   obj:元素对象。   attr:用引号包围的属性名。   iTarget:属性目标值。
        *
        *****************/
    
    
        function Move(obj,attr,iTarget){
            clearInterval(obj.timer);//关闭前一个定时器,解决对同个对象同时调用多个Move()时,定时器叠加问题。使用obj.timer给每个调用Move()的对象赋予各自的定时器,防止多个对象同时调用Move()时,同用一个定时器,而导致相关干扰问题。
            obj.timer=setInterval(function(){
                var cur=0;//创建一个变量,用于存储 attr属性每时每刻的值
                if(attr=="opacity"){
                //针对在FF中opacity属性值为浮点数值问题,将属性值 四舍五入、转换成浮点型。乘以100,使opacity属性值与IE统一为百分数
                    cur=Math.round(parseFloat(getStyle(obj,attr))*100);
                }else{
                    cur=parseInt(getStyle(obj,attr));//将除opacity外的属性(width/fontSize/MarginLeft等)的初始值 转换为整型
                }
                var speed=(iTarget-cur)/10;//创建 递减的速度speed变量。实现属性值的变速改变
    
                speed=speed>0?Math.ceil(speed):Math.floor(speed);//取整,解决浏览器忽略小于1px的数值 导致运动结束时,离目标值Itarget少几个像素的问题
    
                if(iTarget==cur){//当目标值等于目标值时,结束定时器
                    clearInterval(obj.timer);
                }else{
                        cur+=speed;//当前值cur 加上 递减的速度值speed
                    if(attr=="opacity"){
                        // 分别对IE和FF设置opacity属性值
                        obj.style.filter="alpha(opacity:"+cur+")"; //for IE
                        obj.style.opacity=cur/100;   //for FF
                    }else{
                        obj.style[attr]=cur+"px"; //给指定属性attr 添加值cur+speed
                    }
                }
            },30);
        }
        //getStyle()函数 用于兼容IE和FF:获取 对象的 非行间样式中的属性的值。 obj:元素对象。 name:属性名。
        function getStyle(obj,name){
            if(obj.currentStyle){
                return obj.currentStyle[name];//for IE
            }else{
                return getComputedStyle(obj,false)[name];//for FF
            }
        }

    分享自学“智能社“的”JavaScript运动“视频教程后的实践成果~

    推荐JS初学者去看看“智能社“推出的JS教程。

  • 相关阅读:
    python super()函数
    java中的方法
    python的5大数据类型操作之列表篇
    java流程控制
    eval函数 exec函数 compile函数之间的应用
    基础语法
    java中对字符串的操作
    iOS 简单的文件写入
    iOS弹出窗口
    iOS block传值和属性传值
  • 原文地址:https://www.cnblogs.com/slowsoul/p/2921354.html
Copyright © 2011-2022 走看看