js网页特效(一)

1.offset系列

相关属性:

  1. offsetWidth //可视区域区域的
  2. offsetHeith //可视区域的高
  3. offsetTop //从border开始计算
  4. offsetLeft //从border开始计算
  5. offsetParent//距离自身最近的带有定位的父级
    //如果父级没定位 继续往上找 找到body为止

详解:

offsetParent爸爸去哪

  1. 返回该对象距离最近的带有定位的父级

  2. 如果当前元素的所有父级元素都没有定位(position为absolute或relative),
    offsetParent为body

  3. 如果当前元素的父级元素中有定位(position为absolute或relative),
    offsetParent取最近的那个父级元素

  4. 另外注意offsetParent与parentNode的区别parentNode只找自己的上一级(亲爹)

offsetHeight与offsetWidth的构成:

    offsetHeight = height+padding+border
    注意: 包括 自身高度 内边距 边框 不包括 外边距
    offsetWidth = Width+padding+border
    注意: 包括 自身高度 内边距 边框 不包括 外边距

offsetWidth和style.width的区别:

demo.style.height只能获取行内样式,如果样式写到了其他地方,
甚至根本就没写,便无法获取

style.height是字符串(而且带单位),offsetHeight是数值

demo.style.height可以设置行内样式,offsetHeight是只读属性

offsetLeft和style.left的区别

一、style.left只能获取行内样式

二、offsetLeft只读,style.left可读可写

三、offsetLeft是数值,style.left是字符串并且有单位px

四、如果没有加定位,style.left获取的数值可能是无效的

五、最大区别在于offsetLeft以border左上角为基准,style.left以margin左上角为基准

注意:在编写 匀速运动时,要注意margin带来的负面影响。

2.Math()对象

Math对象常用方法:

天花板 向上取整 负数取更大的

  1. Math.ceil(x)

地板 向下取整 负数取更小的

  1. Math.floor(x)

//四舍五入

3.Math.round(x)

取绝对值

4.Math.abs(x)

注意:

 Math.round(-1.5)  等于-1
 Math.round(1.5)  等于-2

3.动画原理

1. 动画原理公式

动画原理公式: leader = leader + step

解释:

leader表示盒子当前位置
step表示步长(相当于速度)
box.style.left = box.offsetLeft + 10 + "px";
让setInterval不断执行某个函数修改盒子的位置属性最后就实现了动画的效果

2.动画函数封装源码:

function animate(obj, target) {
    clearInterval(obj.timer);
    obj.timer = setInterval(function () {
        //leader = leader + step
        var leader = obj.offsetLeft;
        //target-leader
        var step = 10;
        var step = (target - leader) > 0 ? step : -step;
        //
        if (Math.abs(target - leader) > Math.abs(step)) {
            leader = leader + step;
            obj.style.left = leader + "px";
        } else {
            obj.style.left = target + "px";
            clearInterval(obj.timer);
        }
    }, 15)
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • offset家族三大家族和一个事件对象三大家族(offset/scroll/client)事件对象/event ...
    Yuann阅读 1,060评论 0 5
  • 一、三大系列:offset家族、scroll家族、client 1、offset 1.1.简介 offset家族就...
    magic_pill阅读 926评论 0 4
  • 一、自定义动画 延迟执行 start.style.animationDelay = delay + 's'; 二、...
    Jackson_yee_阅读 585评论 0 2
  • 三种定义函数的方式 变量声明提升 在函数体内部,声明变量,会把该声明提升到函数体的最顶端。 只提升变量声明,不赋值...
    J_L_L阅读 393评论 0 2
  • Window和document对象的区别 window对象window对象表示浏览器中打开的窗口window对象是...
    FConfidence阅读 2,354评论 0 5

友情链接更多精彩内容