首页 > 其他分享 >day 16 运动(上)

day 16 运动(上)

时间:2022-10-23 15:55:52浏览次数:59  
标签:target 16 element current step let key 运动 day

概述:运动也就是动画,操作对应的dom元素持续多次的修改样式,并且有比较短的时间的间隔(肉眼无法察觉),达到目标位置后停止,这就是动画

主要实现原理

  • 利用定时器定时操作dom的样式

  • 当对应的设置目标值到达以后清除对应的定时器

运动三大要素

  • 当前值(current)

  • 变化值 (step)

  • 目标值 (target)

主要动画

匀速运动(每次变化的值是一样的)
示例(操作div的宽度变化)

封装的匀速运动代码(如果设置值不一样那么动画将不会一起完成)

//匀速运动的方法
//element表示移动的元素 target 目标位置{width:100,left:500}
function uniformVelocityAnimation(element, targetObj) {
    //遍历target得到他的样式
    for (let key in targetObj) {//key是字符串
        //获取移动的目标样式的值
        let current = parseFloat(getStyle(element)[key])
        //得到目标值
        let target = targetObj[key]
        //步长设置 如果目标值是小于我们当前的值那么对应变化的量为负值 如果目标值大于我们当前值那么变化量为正值
        let step = target>current?10:-10
        //定时更改
        let timer = setInterval(() => {
            //判断是否到达目标位置
            if (current >= target) {
                clearInterval(timer)
            } else {
                //每次将对应的left值更改
                current += step
                //重新设置div的left值
                element.style[key] = current + 'px'
            }
        }, 40)
        }
}
//封装一个方法获取对应的样式(获取所有的样式)
function getStyle(element){
    if(window.getComputedStyle){
        return  window.getComputedStyle(element,'')
    }else{
        return element.currentStyle 
    }
}
缓冲运动 (每次变化的值是越来越小的)

缓冲封装

//缓冲运动封装
//element表示当前的元素 target表示目标对象
function bufferAnimation(element, targetObj) {
    //如果element为undefined就直接报错
    if(!element){
        throw new Error('元素不能缺少')
    }
    //给元素对象添加一个属性为timer他是一个定时器
    element.timer = setInterval(() => {
        var flag = true
        //遍历对象
        for (let key in targetObj) {
            //取出当前值
            let current = parseFloat(getStyle(element)[key])
            //取出目标值
            let target = targetObj[key]
            //判断当前如果是位置的变化及对应的宽度高度的变化
            if(key=='width' || key == 'height' || key == 'left' || key == 'top'){
                //步长 负值向下取整 正值向上取整
                var step = target-current>0?Math.ceil((target - current) / 10):Math.floor((target - current) / 10)
                current += step
                element.style[key] = current + 'px'
            }
            //如果是透明度的变化
            if(key == 'opacity'){
                //步长 负值向下取整 正值向上取整
                var step = target-current>0?Math.ceil((target - current) * 1000 / 10):Math.floor((target - current)*1000 / 10)
                current += step / 1000
                element.style[key] = current
            }
            //如果是层高直接赋值
            if(key == 'zIndex'){
                element.style[key] = target
            }
            //如果没有完成就是false
            if(current != target){
                flag = false
            }
        }
        //如果全部走完了就清除
        if(flag){
            clearInterval(element.timer)
        }
    },80)
}
//封装一个方法获取对应的样式(获取所有的样式)
function getStyle(element) {
    if (window.getComputedStyle) {
        return window.getComputedStyle(element, '')
    } else {
        return element.currentStyle
    }
}

 

标签:target,16,element,current,step,let,key,运动,day
From: https://www.cnblogs.com/zmfhtml5/p/16818728.html

相关文章

  • day17 运动(下)
    day17运动(下)链式动画动画执行完接另一个动画不断进行链接。封装进行(通过传入回调函数完成链式运动)//缓冲运动封装//element表示当前的元素target表示目标对象callb......
  • 海思3516系列芯片SPI速率慢问题深入分析与优化(基于PL022 SPI 控制器)
    海思3516系列芯片SPI速率慢问题深入分析与优化(基于PL022SPI控制器)我在某个海思主控的项目中需要使用SPI接口来驱动一块液晶屏,液晶屏主控为st7789,分辨率240x240,图像格......
  • Codeforces 1682 D Circular Spanning Tree
    题意1-n排列,构成一个圆;1-n每个点有个值0或者1,0代表点的度为偶数,1代表点的度为计数;询问能否构成一棵树,树的连边在圆内不会相交,在圆边上可以相交,可以则输出方案。提示1.......
  • 前端Vue2-Day57
    处理跨域:①cors ②JSONP③配置代理服务器配置代理:均需要在vue.config.js中进行配置方法一:直接定义代理服务器转发地址proxy,客户端请求url为代理服务器地址 de......
  • 基于HTML体育运动兵乓球网站项目的设计与实现【学生网页设计作业源码】
    ......
  • Day4:IDEA开发工具使用&面试题拓展
    IDEApsvm:生成main方法sout:生成输出语句注释:注释、标识符、关键字;数据类型;类型转换;变量、常量;运算符;包机制、JavaDoc一、注释(单行/多行/文档)创建一个空文件空......
  • 【Odoo】Odoo16-性能优化提升
    上海序说科技,专注于基于Odoo项目实施,实现企业数智化,助力企业成长。老韩头的开发日常,博客园分享(2022年前博文)10月12日,Odoo16版本正式发布,本文将就Odoo官方在性能方面做......
  • 【leetcode_C++_哈希表_day5】242. 有效的字母异位词&&349. 两个数组的交集&&202.快乐
    C++知识补充:(不完全,仅针对本题用的知识点)1.C++类&对象关键字public确定了类成员的访问属性。在类对象作用域内,公共成员在类的外部是可访问的。您也可以指定类的成......
  • leetcode-169-easy
    MajorityElement思路一:mappublicintmajorityElement(int[]nums){if(nums.length==1)returnnums[0];Map<Integer,Integer>map=newHashMap<>(......
  • 工作日志Day n+2
    1、MPJLambdaWrapper(mybatis-plus-join)便于关联查询。构建查询条件的核心:selectAll():查询指定实体类的全部字段select():查询指定的字段,支持可变长参数同时查询多个字段......