发布时间:2024-07-20 10:01
目录
一、H5的简单布局
二、css的布局
三、获取元素
四、使用js来实现‘盒子’移动
效果展示
五、使用js来实现缓动效果
效果展示
六、完整代码评论区自取
简易的布局出两个不同颜色的‘盒子’。
var box1 = document.querySelector('.box1');
var box2 = document.querySelector('.box2');
可以使用函数封装,来实现,修改调用,不需要在代码中修改,可以减少出错的几率。
function myRun(box,h1,h2){ //封装函数
var myInter = setInterval(function(){
var offsetLeft = box.offsetLeft;
var num = h1; //每次都移动h1个像素
var target = h2; //一共移动的距离
if(offsetLeft==target){ //通过if来判断,到达了设定距离,就会删除间隔函数
clearInterval(myInter);
}else{
box.style.left = offsetLeft+num+'px';//没有达到距离,一直赋值给‘盒子’左边距
}
},1000)}
box1.onclick=function(){
myRun(this,50,200); } //给‘盒子’设计点击事件,点击才会出现移动,this指向box1,里面是所调用的值,可以直接在里面修改,移动一次的距离,一共移动的距离
依旧可以使用函数来封装,达到简洁的效果
大致代码与js移动相同,中间判断与上文稍微有些不同,其中的含义是,第一次移动取移动距离的十分之一,接下来的每一次移动,都是取省下来还剩多少距离的十分之一,取整是为了,在无线接近于所设置的距离可以移动。
function move(obj,sum){
var liLi = setInterval(function(){
var offsetLeft =obj.offsetLeft;
var num = (sum - offsetLeft)/10;
num > 0 ? Math.ceil(num):Math.floor(num);
if(offsetLeft==sum){
clearInterval(liLi);
}else{
obj.style.left = offsetLeft+num+'px';
}
},1000)
} box2.onclick=function(){
move(this,200);
}
master节点重置后添加node报错_Prometheus监控Kubernetes 集群节点及应用
vue@cli4 和 webpack5【实现自适应px-rem转化】
SpringBoot——SpringBoot 集成 Thymeleaf 模板
使用vite构建一个自己的vue3.0的UI组件库,并发布到npm
【动手学基于Python+Tensorflow+CNN深度学习的轴承故障诊断(西储大学数据集)(含完整代码)】
iot架构 mqtt netty_Netty实现高性能IOT服务器(Groza)之手撕MQTT协议篇上