原生JS实现圆环拖拽效果
程序员文章站
2022-06-05 22:44:46
最近用原生js写一个环形的鼠标滑动效果,代码如下:
最近用原生js写一个环形的鼠标滑动效果,代码如下:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>title</title> <style> *{margin:0;padding:0;} div{width:50px;height:50px;border-radius:50%;position: absolute; border-width:10px;border-style: solid;} </style> </head> <body> </body> <script> var divlist=[];//创建一个空的集合,用来存储创建的div for(i=0;i<50;i++){//循环次数50,创造50个div(环形) var div=document.createelement("div"); var red=math.round(math.random()*255); var green=math.round(math.random()*255); var yellow=math.round(math.random()*255);//(产生随机数作为环形的颜色) div.style.bordercolor="rgb("+red+","+green+","+yellow+")"; document.body.appendchild(div);//在文档中产生环形 divlist[divlist.length]=div;//将产生的每一个环形放入空集合 } document.onmousemove=function(e){//先鼠标按下获取相对位置 var evt=window.event || e;//ie兼容 var x=evt.clientx+(document.documentelement.scrollleft||document.body.scrollleft);//鼠标当前x位置 var y=evt.clienty+(document.documentelement.scrolltop||document.body.scrolltop);//鼠标当前y位置 divlist[0].style.left=x+"px";//第一个环形的x位置 divlist[0].style.top=y+"px";//第一个环形的y位置 for(i=divlist.length-1;i>0;i--){//循环让每一个环形都在它上一个的位置 divlist[i].style.left=divlist[i-1].offsetleft+"px"; divlist[i].style.top=divlist[i-1].offsettop+"px"; } } </script> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。