zoukankan      html  css  js  c++  java
  • 运动框架

    运动框架演变过程
    startMove(iTarget) 运动框架
    startMove(obj, iTarget) 多物体
    startMove(obj, attr, iTarget) 任意值
    startMove(obj, attr, iTarget, fn) 链式运动
    startMove(obj, json) 多值运动
    startMove(obj, json, fn) 完美运动框架

    完美运动框架:(下面是讲解)

    
    
    function startMove(obj, json, fnEnd)//json顶替了之前iTarget的位置
    {
        clearInterval(obj.timer);
        obj.timer=setInterval(function (){

            var bStop=true; //新引进的变量 假设:所有值(width/height/opacity)都已经到达目标了 因 300, height: 101而生 即倘若两个变化差很大肉眼可见无法同时到达
            
            for(var attr in json)
            {
    //
                var cur=0;
                if(attr=='opacity')
                {
                    cur=Math.round(parseFloat(getStyle(obj, attr))*100);
                }
                else
                {
                    cur=parseInt(getStyle(obj, attr));
                }
                
                var speed=(json[attr]-cur)/6;/////这里
                speed=speed>0?Math.ceil(speed):Math.floor(speed);

                if(cur!=json[attr]) /////这里
                bStop=false;//一旦有一个json元素未达到目标 就改变变量的值
                
             if(attr=='opacity')
                {
                    obj.style.filter='alpha(opacity:'+(cur+speed)+')';
                    obj.style.opacity=(cur+speed)/100;
                }
                else
                {
                    obj.style[attr]=cur+speed+'px';
                }
    //是之前的内容(有iTarget的时候) 现在用上了json+for-in循环
            }
            
            if(bStop) //bstop为真 就是没有执行上面那个if语句 没有东西没到目标
            {
                clearInterval(obj.timer);//关掉定时器
                            
                if(fnEnd)fnEnd();//如果有函数就执行函数
            }
        }, 30);
    }
     

     完美运动框架:可以多个值同时变化

    Json+for-in+新变量(var bStop=true

     

  • 相关阅读:
    电力企业信息化建设方案之调度信息报送系统
    HP QC IE11不支持( win7 64位 无法安装)解决方法
    ajax传递list集合
    mysql主从配置
    js动态获取地址栏后的参数
    html页面保存数的两种方式
    微信开发之八 页面获取周围beacon设备
    最好的时光在路上,最美的风景在远方
    【摄影】田子坊
    【前端统计图】echarts实现简单柱状图
  • 原文地址:https://www.cnblogs.com/yundong333/p/10403456.html
Copyright © 2011-2022 走看看