我正在使用所选项目创建圈子导航。当用户单击任何项目时,它将移动到定义的特定点。一切正常,除非您继续单击项目,否则动画会有所不同,并且项目会以360度旋转并重置,直到您重复该场景为止。我希望它像第一次使用时一样平滑,就像有多少用户单击它应该可以平稳移动的项目。
代码JSFIDDLE LINK单击项目后,您将看到该行为
// rotate circle functions
var p = $(".cirlec-slider-bg");
$(".cirlec-slider-bg .f-courses").clone().appendTo(p);
var a = -($('.cirlec-slider-bg').width() / 2);
var b = $('.cirlec-slider-bg .f-courses').length;
var c = 360 / b;
rotateCircle(c, 'domReady');
$(".cirlec-slider-bg").on("click", ".f-courses", function(e) {
if ($(this).hasClass('active')) {} else {
$('.cirlec-slider-bg .f-courses').removeClass("active");
$(this).addClass('active');
var dataAngle = parseInt($(this).attr('data-angle'));
var maxangle = 90 - dataAngle;
rotateCircle(maxangle, 'onitemClick')
}
});
function rotateCircle(maxangle, type) {
$('.cirlec-slider-bg .f-courses').each(function(index) {
if (type == 'onitemClick') {
var maxAngle = maxangle;
var dataAngle2 = parseInt($(this).attr('data-angle'));
var maxangle2 = dataAngle2 + maxAngle;
var d = (index) * c;
}
if (type == 'domReady') {
var maxAngle = maxangle;
var maxangle2 = (index) * maxAngle;
}
var m = [
"translate(-50%, -50%) rotate(", -90, "deg) translateY(" + 100 + "px) rotate(", 90, "deg)"
];
m[1] = maxangle2;
m[3] = 0 - maxangle2;
$(this).css({
"transform": m.join("")
});
$(this).attr('data-angle', maxangle2);
})
}
答案 0 :(得分:1)
在点击处理程序中打印dataAngle
的值表明,有时它超出了[0, 180]
的允许范围-它可以变为负数或大于360。
解决方法是在检索dataAngle
之后添加以下行:
dataAngle -= Math.floor(dataAngle / 360.0) * 360;
(请注意,这与dataAngle % 360
不同)