运动框架之使用,缩放1

本文介绍了如何使用JavaScript来创建缩放功能,首先通过布局转换,设置元素的left和top属性,然后将浮动元素转换为定位。在定位过程中需要注意去除margin值以避免布局错误。接着,当元素悬浮时,围绕中心点进行放大,并调整left和top的位置。文章中提到了一个完美运动框架的使用,通过传入正确的坐标点即可实现平滑的缩放效果。在缩小回原状态时,需要将元素移回原位置。作者强调,虽然代码可能显得冗长,但初学者也能理解并实现,且同样的功能可以有多种实现方式,高明的开发者倾向于使用最简洁的方法。
摘要由CSDN通过智能技术生成

上一篇我用css3 写了个缩放的功能,这次我们用js 写!

 

上面是布局,

 

我们来看下代码

我们发现坐标刚好就是我们要定位时的坐标,为了防止布局出现错误

我们采取,先给每个元素设置好,

left 和top,然后统一将浮动的元素,转成定位!

 

但是定位时,要去掉margin 值,因为你的定位坐标已经包含了margin

如果定位后,还加margin ,此时margin 值仍然会起作用,就重复了, 所以要去掉!

 

第一步的布局转换就完毕了,下一步就是当悬浮的时候,放大,沿着中心点放到!

 

 

 // 当页面加载完毕的时候,我们在这里写代码!
        window.onload = function(){
            var zIndex = 2;
            var oBox = document.getElementById('box');
            var aLis = oBox.getElementsByTagName('li');
            var w = aLis[0].offsetWidth;
            var h = aLis[0].offsetHeight;

            for(var i =0; i<aLis.length;i++){
                var left = aLis[i].offsetLeft;
                var top = aLis[i].offsetTop;
                // 一次性就能得到 li的定位坐标,很溜
                aLis[i].style.left = left + 'px';
                aLis[i].style.top = top + 'px';
                aLis[i].c = {
                    left,top
                };
                
            }
            for(var i =0; i<aLis.length;i++){
                
                aLis[i].style.position = 'absolute';
                aLis[i].style.margin = '0';
            }
            for(var i =0; i<aLis.length;i++){
               
             
                aLis[i].onmouseover = function(){
                   
                   var rLeft  = this.c.left - this.offsetWidth/2;
                   var rTop = this.c.top - this.offsetHeight/2;
                   // 1, 先向上向左移动自身宽度的一半!
                   // 2, 然后宽高放大一倍!
                   // 3, 这个时候就需要用到万能框架!
                   startMove(this,{
                       left:rLeft,
                       top:rTop,
                       width:w*2,
                       height:h*2
                   });
                   this.style.zIndex = zIndex++;
               }
               aLis[i].onmouseout = function(){
                startMove(this,{
                       width:w,
                       height:h,
                       left:this.c.left,
                       top:this.c.top
                   });
               }

           }
        }
    </script>

 

上面的代码用到了,完美运动框架:

/**
 * @author miaov
 */
function getStyle(obj, attr)
{
	if(obj.currentStyle)
	{
		return obj.currentStyle[attr];
	}
	else
	{
		return getComputedStyle(obj, false)[attr];
	}
}

function startMove(obj, json, fn)
{
	clearInterval(obj.timer);
	obj.timer=setInterval(function (){
		var bStop=true;		
		for(var attr in json)
		{

			var iCur=0;
			
			if(attr=='opacity')
			{
				iCur=parseInt(parseFloat(getStyle(obj, attr))*100);
			}
			else
			{
				iCur=parseInt(getStyle(obj, attr));
			}
			
		
			var iSpeed=(json[attr]-iCur)/8;
			iSpeed=iSpeed>0?Math.ceil(iSpeed):Math.floor(iSpeed);
			
		
			if(iCur!=json[attr])
			{
				bStop=false;
			}
			
			if(attr=='opacity')
			{
				obj.style.filter='alpha(opacity:'+(iCur+iSpeed)+')';
				obj.style.opacity=(iCur+iSpeed)/100;
			}
			else
			{
				obj.style[attr]=iCur+iSpeed+'px';
			}
		}
		
		if(bStop)
		{
			clearInterval(obj.timer);
			
			if(fn)
			{
				fn();
			}
		}
	}, 30)
}

 

 

使用的时候,只要将坐标点,传对,基本这个程序就没问题了,

 

放到的时候, left top 要往右上角去移!

缩小的时候要移回来!

 

 

 

可以发现我写的代码和啰嗦,都这样,菜鸟你写起来也索罗,不信试试

 

为了简化代码,我用marignLeft 代替定位的坐标:

// 当页面加载完毕的时候,我们在这里写代码!
        window.onload = function(){
            var zIndex = 2;
            var oBox = document.getElementById('box');
            var aLis = oBox.getElementsByTagName('li');
            for(var i =0; i<aLis.length;i++){
                var left = aLis[i].offsetLeft;
                var top = aLis[i].offsetTop;
                // 一次性就能得到 li的定位坐标,很溜
                aLis[i].style.left = left + 'px';
                aLis[i].style.top = top + 'px';
            }
            for(var i =0; i<aLis.length;i++){
                
                aLis[i].style.position = 'absolute';
                aLis[i].style.margin = '0';
            }
            for(var i =0; i<aLis.length;i++){
               
             
                aLis[i].onmouseover = function(){
                   startMove(this,{
                       marginLeft:-100,
                       marginTop:-100, 
                       width:400,
                       height:400
                   });
                   this.style.zIndex = zIndex++;
               }
               aLis[i].onmouseout = function(){
                startMove(this,{
                        marginLeft:0,
                       marginTop:0,   
                       width:200,
                       height:200,
                          
                   });
               }

           }
        }
    </script>

 

 

也能实现功能,可见一个功能,可以用不同的方式实现,高手总是会用最简单的!

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值