这篇文章主要讲解了“javascript如何操作单个dom元素添加动画”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript如何操作单个dom元素添加动画”吧!
我们是从2013年开始的成都网站建设公司,提供网站建设,电商网站设计开发,外贸营销网站建设,响应式网页设计,成都微信小程序、等服务。为客户创造有价值的品牌营销体验,让互联网提升企业的竞争力!
让一个元素从左至右进行运动
var box = document.getElementById("box"); var t = null; t = setInterval(function(){ })
t = setInterval(function(){终止条件})
// 元素的属性值 === 目标点 if(dom.attr === target){ clearInterval(t); }
起始点
一个运动的起始点其实就是当前元素的位置,我们通过API获取当前元素的位置,让这个位置作为运动的起始。
目标
速度
让元素通过定时器在很短的间隔内进行CSS属性值的改变
这样连续的运动在用户看来就是动画效果
封装的主要作用就是让元素可以在短时间间隔内不断改变属性实现动画效果
单属性运动框架:
匀速运动封装
兼容透明度
缓冲运动
缓冲运动是一种运动方式
这种运动方式是速度在运动过程中会有改变的运动
距离越小 速度越小
//只需要改变里面transition的值就可以调整运动模式//buffer为缓冲运动//liner为匀速运动
多属性运动框架
我们在多次调用animate的时候会开启多个定时器
因为定时器之中的数据都一样,我们看不出在效果上的差异
但是多次开启定时器会极其严重的消耗计算机性能
开启当前定时器之前关闭上一个定时器
示例如下
项目背景:uniapp h6应用,为了提示用户下载,这里有个 提示下载的dom, 本想来想在 每个 tabbar 中添加(一共添加四个);但是想 尝试换种玩法 如下: 效果如下:
直接上代码:
function showDownloadTisp() { console.log('--------------------------->showDownloadTisp') // #ifdef H5 const parent = document.querySelector('.uni-tabbar') console.log('parent:', parent) const tips = document.createElement('p') tips.id = 'downloadTisp' tips.setAttribute('style', 'background: rgba(51,51,51,0.75);' ) tips.setAttribute('style', `background: rgba(51,51,51,0.75); position: fixed;width: 100%;height: ${uni.upx2px(120)}px; bottom:${uni.upx2px(-140)}px; display: flex;flex-direction: row;justify-content: space-between;align-items:center;transition:0.5s;` ) const desParent = document.createElement('p') const des = document.createTextNode('Download our App, you will get a better experience.') desParent.appendChild(des) desParent.setAttribute('style', `padding: 0;color: #FFFFFF;font-size:${uni.upx2px(24)}px;margin-left: ${uni.upx2px(27)}px;padding-right: ${uni.upx2px(25)}px;` ) const iosImage = document.createElement('img') iosImage.src = '../static/guide/download ios.png' iosImage.setAttribute('style', `width: ${uni.upx2px(154)}px;height: ${uni.upx2px(54)}px;margin-right: ${uni.upx2px(25)}px;`) const anroidImage = document.createElement('img') anroidImage.src = '../static/guide/download android.png' anroidImage.setAttribute('style', `width: ${uni.upx2px(154)}px;height: ${uni.upx2px(54)}px;margin-right: ${uni.upx2px(50)}px;`) const closedImage = document.createElement('img') closedImage.src = '../static/guide/download closd.png' closedImage.setAttribute('style', `width: ${uni.upx2px(30)}px;height: ${uni.upx2px(30)}px;position: absolute;right:${uni.upx2px(15)}px;top: ${uni.upx2px(15)}px;padding: ${uni.upx2px(5)};` ) tips.appendChild(desParent) tips.appendChild(iosImage) tips.appendChild(anroidImage) tips.appendChild(closedImage) iosImage.onclick = () => { //console.log("iosImage.onclick") window.location.href = 'https://apps.apple.com/cn/app/gbm001/id1574324240' // window.open('https://www.baidu.com/') } anroidImage.onclick = () => { //console.log("anroidImage.onclick") window.location.href = 'https://play.google.com/store/apps/details?id=com.vandream.gbmpro' // window.open('https://www.sina.com.cn/') } closedImage.onclick = () => { console.log("closedImage.onclick") tips.remove() } parent.parentNode.appendChild(tips) //parent.appendChild(tips) setTimeout(() => { tips.style.transform = `translateY(${uni.upx2px(-140) - 50}px);` //console.log(" tips.style.transform done") }, 2500) // #endif }
通过代码创建节点 并且代码这是 style; 以及动画;在应用启动的时候 调用就可以了;
关于 js 设置变换动画;这边改成了 3D 的形式
function showDownloadTisp() { // #ifdef H5 const parent = document.querySelector('.uni-tabbar') // console.log('parent:', parent) const tips = document.createElement('p') tips.id = 'downloadTisp' // tips.setAttribute('style', // 'background: rgba(51,51,51,0.75);' // ) // tips.setAttribute('style', // `background: rgba(51,51,51,0.75); position: fixed;width: 100%;height: ${uni.upx2px(120)}px; bottom:${uni.upx2px(-140)}px; display: flex;flex-direction: row;justify-content: space-between;align-items:center;transition:0.5s;` // ) tips.setAttribute('style', `background: rgba(51,51,51,0.75); position: fixed;width: 100%;height: ${uni.upx2px(120)}px; bottom:50px; display: flex;flex-direction: row;justify-content: space-between;align-items:center;transition:0.5s; transform-origin:center bottom; transform:perspective(900px) rotateX(90deg);` ) const desParent = document.createElement('p') const des = document.createTextNode('Download our App, you will get a better experience.') desParent.appendChild(des) desParent.setAttribute('style', `padding: 0;color: #FFFFFF;font-size:${uni.upx2px(24)}px;margin-left: ${uni.upx2px(27)}px;padding-right: ${uni.upx2px(10)}px;` ) const iosImage = document.createElement('img') // iosImage.src = '../static/guide/download ios.png' iosImage.src = 'https://img.vandream.com/54/0330f6211506cc.png' iosImage.setAttribute('style', `width: ${uni.upx2px(154)}px;height: ${uni.upx2px(54)}px;margin-right: ${uni.upx2px(25)}px;`) const anroidImage = document.createElement('img') // anroidImage.src = '../static/guide/download android.png' anroidImage.src = 'https://img.vandream.com/53/0330f45097465d.png' anroidImage.setAttribute('style', `width: ${uni.upx2px(154)}px;height: ${uni.upx2px(54)}px;margin-right: ${uni.upx2px(50)}px;`) const closedImage = document.createElement('img') // closedImage.src = '../static/guide/download closd.png' closedImage.src = 'https://img.vandream.com/52/0330f523d7709d.png' closedImage.setAttribute('style', `width: ${uni.upx2px(30)}px;height: ${uni.upx2px(30)}px;position: absolute;right:${uni.upx2px(15)}px;top: ${uni.upx2px(15)}px;padding: ${uni.upx2px(5)};` ) tips.appendChild(desParent) tips.appendChild(iosImage) tips.appendChild(anroidImage) tips.appendChild(closedImage) iosImage.onclick = () => { console.log('iosImage.onclick') window.location.href = 'https://apps.apple.com/cn/app/gbm001/id1574324240' // window.open('https://www.baidu.com/') } anroidImage.onclick = () => { console.log('anroidImage.onclick') window.location.href = 'https://play.google.com/store/apps/details?id=com.vandream.gbmpro' // window.open('https://www.sina.com.cn/') } closedImage.onclick = () => { console.log('closedImage.onclick') tips.remove() } parent.parentNode.appendChild(tips) // parent.appendChild(tips) setTimeout(() => { // tips.style.transform = `translateY(${uni.upx2px(-140) - 50}px);` tips.style.transform = 'rotateX(0deg)' // console.log(" tips.style.transform done"):rotateX(90deg); }, 2500) // #endif }
感谢各位的阅读,以上就是“javascript如何操作单个dom元素添加动画”的内容了,经过本文的学习后,相信大家对javascript如何操作单个dom元素添加动画这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!