龙空技术网

JavaScript制作滑动动效

传智教育官方账号 240

前言:

今天姐妹们对“js滚动鼠标”大概比较珍视,兄弟们都想要了解一些“js滚动鼠标”的相关文章。那么小编在网上搜集了一些关于“js滚动鼠标””的相关资讯,希望同学们能喜欢,朋友们一起来了解一下吧!

1.动画效果描述

当我们用鼠标点击滑块时就可以拖拽,当滑块左外边距超过背景开关宽度的一半时,灯泡亮起;小于一半时,灯泡熄灭。当我们中途鼠标按键抬起时,如果滑块左外边距超过背景开关宽度的一半,那么滑块最终居右;反之,滑块最终居左。

2. html代码准备

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>电灯开关</title>    <style>        div{            /*border: 1px solid red;*/            width: 140px;            height: 40px;            margin: auto;            background: url("./img/switch.png");        }    </style></head><body>    <center>        <img src="img/off.gif" id="light">    </center>    <div>        <img src="img/button.png" id="slideBtn">    </div></body></html>
3. 拖拽分析

鼠标移动多大的距离(moveX-startX),那么滑块也移动多大的距离,要想让滑块移动,最简单的做法可以直接修改滑块的margin-left样式值。如图所示:

4. JavaScript代码实现动画

<script>        window.onload=function () {            //获取滑块按钮元素对象            var slideBtn = document.getElementById("slideBtn");            //获取背景开关div的宽度            var mWidth = document.getElementById("switchBg").offsetWidth;            //获取灯泡图片元素            var light=document.getElementById("light");            //定义一个变量表示是否按下鼠标            var isDown=false;//默认没有按下            var startX;//按下点X轴坐标            var marginLeft=0;//默认左外边距是0            var flag=false;//默认灯泡没有亮            //绑定鼠标按下事件            slideBtn.onmousedown=function () {                //表示已经按下了                isDown=true;                //保存按下的点X坐标值                startX=event.screenX;                return false;            }            //绑定鼠标移动事件            slideBtn.onmousemove=function () {                if(isDown){//按下了之后才执行拖拽操作                    //获取移动的坐标x                    var moveX = event.screenX;                    //计算查找,也就是移动的距离                    var dx=moveX-startX;                    startX=moveX;                    //让滑块按钮左外边距移动dx像素                    marginLeft+=dx;                    //marginLeft不能大于mWidth/2,不能小于0                    marginLeft=marginLeft>=mWidth/2?mWidth/2:marginLeft;                    marginLeft=marginLeft<=0?0:marginLeft;                    //设置滑块按钮的左外边距                    slideBtn.style.marginLeft=marginLeft+"px";                    //如果左外边距>mWidth/4 px,那么灯泡就亮                    if(marginLeft>=mWidth/4 && !flag){                        light.src="img/on.gif"                        flag=!flag                    }else if (marginLeft<=mWidth/4 && flag){                        light.src="img/off.gif"                        flag=!flag                    }                }                return false;            }            //绑定鼠标按键抬起事件            slideBtn.onmouseup=function () {                //最终按钮要复位,左外边距<mWidth/4就回到最左边,否则回到最右边                slideBtn.style.marginLeft=(marginLeft>=mWidth/4)?mWidth/2+"px":"0px"                isDown=false;//鼠标按键抬起了            }            //鼠标移出事件            slideBtn.onmouseout=function () {                isDown=false;//鼠标按键抬起了,否则下次在移入到滑块身上,isDown还是true,会导致我们没有按下鼠标就能拖动滑块            }        }    </script>
5. 总结:

这是一个比较简单的小动画,当然我们不使用margin-left也能完成。比如使用定位,我们可以使用相对定位来个开关和背景布局,修改开关的left值也是一样的。但是涉及到的事件依然是鼠标的按下、移动、抬起、移除事件。

标签: #js滚动鼠标