这篇文章主要为大家详细介绍了js实现圆形菜单选择器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了js实现圆形菜单选择器的具体代码,供大家参考,具体内容如下
代码:
.mask{
position: absolute;
width: 502px;
height: 252px;
left:300px;
top:350px;
background: white;
z-index: 999;
}
.con {
width: 500px;
height: 500px;
overflow: hidden;
position: absolute;
border-radius: 100%;
border: 1px solid black;
user-select: none;
cursor: pointer;
left: 300px;
top: 100px;
}
.con>div {
position: absolute;
width: 250px;
height: 250px;
/* border:1px solid black; */
top: 0;
left: 125px;
text-align: center;
font-size: 16px;
transform-origin: bottom center;
}
.con1 {
width: 400px;
height: 400px;
/* background: yellow; */
overflow: hidden;
position: absolute;
border-radius: 100%;
border: 1px solid black;
user-select: none;
cursor: pointer;
left: 350px;
top: 150px;
}
.con1>div {
position: absolute;
width: 200px;
height: 200px;
/* border:1px solid black; */
top: 0;
left: 100px;
text-align: center;
font-size: 16px;
transform-origin: bottom center;
}
<meta name="viewport"
content=”width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no” />
conRender();
conRender1();
function conRender() {
var con = document.querySelector(“.con”);
var len = 16;
var deg = 360 / len;
for (var i = 0; i < len; i++) {
var dom = document.createElement(“div”);
dom.style.transform = “rotate(-” + i * deg + “deg)”;
dom.innerHTML = “财务管理” + i;
dom.setAttribute(“index”, i)
con.appendChild(dom)
}
var mouseDown = false;
var startX = 0;
var startY = 0;
var endX = 0;
var endY = 0;
var rotate = 0;
con.addEventListener(“mousedown”, function (e) {
mouseDown = true;
startX = e.pageX;
startY = e.pageY;
}, false);
con.addEventListener(“mousemove”, function (e) {
if (mouseDown) {
endX = e.pageX;
endY = e.pageY;
var distance = Math.sqrt(Math.pow((endX – startX), 2) + Math.pow((endY – startY), 2))
if (endX – startX < 0 || endY – startY < 0) {
distance = -distance
}
rotate += distance
con.style.transform = “rotate(” + (rotate / 4) + “deg)”;
startX = e.pageX;
startY = e.pageY;
var index = Math.round((rotate / 4) / deg);
var cons = document.querySelectorAll(“.con>div”)
for (var i = 0, len = cons.length; i < len; i++) {
cons[i].style.color = “black”
}
document.querySelector(“div[index=\”” + index % len + “\”]”).style.color = “red”
document.querySelector(“.con1”).style.transform = “rotate(” + (rotate) + “deg)”;
}
}, false);
document.addEventListener(“mouseup”, function (e) { mouseDown = false; }, false);
}
function conRender1() {
var con = document.querySelector(“.con1”);
var len = 13;
var deg = 360 / len;
for (var i = 0; i < len; i++) {
var dom = document.createElement(“div”);
dom.style.transform = “rotate(-” + i * deg + “deg)”;
dom.innerHTML = “财务管理” + i;
dom.setAttribute(“index1”, i)
con.appendChild(dom)
}
var mouseDown = false;
var startX = 0;
var startY = 0;
var endX = 0;
var endY = 0;
var rotate = 0;
con.addEventListener(“mousedown”, function (e) {
mouseDown = true;
startX = e.pageX;
startY = e.pageY;
}, false);
con.addEventListener(“mousemove”, function (e) {
if (mouseDown) {
endX = e.pageX;
endY = e.pageY;
var distance = Math.sqrt(Math.pow((endX – startX), 2) + Math.pow((endY – startY), 2))
if (endX – startX < 0 || endY – startY < 0) {
distance = -distance
}
rotate += distance
con.style.transform = “rotate(” + (rotate / 4) + “deg)”;
startX = e.pageX;
startY = e.pageY;
var index = Math.round((rotate / 4) / deg);
var cons = document.querySelectorAll(“.con1>div”)
for (var i = 0, len = cons.length; i < len; i++) {
cons[i].style.color = “black”
}
document.querySelector(“div[index1=\”” + index % len + “\”]”).style.color = “red”
}
}, false);
document.addEventListener(“mouseup”, function (e) { mouseDown = false; }, false);
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
来源:脚本之家
链接:https://www.jb51.net/article/201314.htm
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:SEO优化专员,转转请注明出处:https://www.chuangxiangniao.com/p/896930.html