var datalist = [
{ time: 2023 },
{ time: 2022 },
{ time: 2021 },
{ time: 2020 },
{ time: 2019 },
{ time: 2018 },
{ time: 2017 }
];
// 请求接口前缀 3.6.1 中文列表
var Baseurl = "https://xhwebapitest.xhkjedu.com/dh/listc";
$.ajax({
type: "POST",
url: Baseurl,
dataType: "json",
async: false,
contentType: "application/json; charset=utf-8",
success: function (data) {
if (data.code === 0) {
// datalist = data.obj;
} else {
alert(data.msg);
}
}
});
var html = "";
$.each(datalist, (idx, item) => {
html += `
`;
});
$(".rounds").width(datalist.length * 2.34 + "rem");
$(".rounds").html(html);
$(".round_q:first").addClass("active"); //默认第一个添加背景色
function showdata(index) {
var list = datalist[index].details,
html = '';
if (!list || list.length == 0) {
return;
}
$.each(list, (idx, item) => {
if (idx % 4 == 0 && idx) {
html += '
';
}
html += `
${item.dhmonth} - ${item.content}
`;
});
if (list.length < 9) {
html += '
';
} else if (list.length < 5) {
html += '
';
}
$(".develop_data").html(html);
}
//获取元素
var divwidth = $(".round_q:first").width() - 54;
var container = $(".showdata");
var list = $(".rounds");
var buts = $(".round_q");
var prev = $(".leftjt");
var next = $(".rightjt");
var index = 1; //存放当前显示的图片的下标
var len = 5; //显示数量
var interval = 5000; //位移时间间隔
var timer;
var offsetpx = (datalist.length - len) * divwidth; //可偏移度
var offleft = 0; //当前偏移量
function animate(offset) {
if (datalist.length <= 5) {
return;
}
var left = parseInt(list.css("left")) + offset;
var absnum = Math.abs(offset);
if (left < 0 - offsetpx) {
//右侧没有数据时不偏移
return;
}
// 边界判断
if (offset > 0) {
offset = "+=" + offset;
offleft = offleft + absnum;
} else {
offset = "-=" + Math.abs(offset);
offleft = offleft - absnum;
}
if (index < 5 && offleft >= 0) {
return;
}
list.animate({ left: offset }, 300, function () {
if (left > -200) {
// list.css("left", (0 - offset) * len);
}
if (index == datalist.length) {
//轮播最后一条
offset = 0 - (datalist.length - 5) * absnum;
offleft = offset;
list.css("left", offset);
}
});
}
//点击高亮滚动
function animates(offset) {
if (datalist.length <= 5) {
return;
}
var left = parseInt(list.css("left")) + offset; //获取元素属性
if (index < 6 && left >= 0) {
list.animate({ left: 0 }, 300, function () {});
return;
}
// 边界判断
if (left < 0 - offsetpx) {
offset = 0 - offsetpx;
} else {
if (offset > 0) {
offset = "+=" + divwidth;
offleft = offleft;
} else {
offset = "-=" + divwidth;
offleft = offset;
}
}
list.animate({ left: offset }, 300, function () {});
}
//亮起小圆点
function showButton() {
//当前图片的小圆点亮起,其他小圆点不亮
buts
.eq(index - 1)
.addClass("active")
.siblings()
.removeClass("active");
}
$(".develop_container").bind("mouseenter", () => {
clearTimeout(timer);
timer=null;
});
$(".develop_container").bind("mouseleave", () => {
play();
});
// 鼠标离开图片区域时,轮播继续
function play() {
if (datalist.length <= 5) {
return;
}
timer = setTimeout(function () {
next.trigger("click");
play();
}, interval);
}
//鼠标进入图片区域时,停止轮播
function stop() {
if (timer) {
clearTimeout(timer);
timer=null;
}
}
// 右按钮点击事件
next.bind("click", function () {
if (datalist.length <= 5) {
return;
}
// 判断当前是否在动画
if (list.is(":animated")) {
return;
}
// 判断当前图片是否是最后一张
if (index == datalist.length) {
index = 1;
offleft = 0;
list.animate({ left: 0 }, 300, () => {});
} else {
index += 1;
}
animate(0 - divwidth);
showdata(index - 1);
showButton();
stop();
});
// 左按钮事件
prev.bind("click", function () {
if (datalist.length <= 5) {
return;
}
// 判断当前是否在动画
if (list.is(":animated")) {
return;
}
// 判断当前图片是否是第一张
if (index == 1) {
index = datalist.length;
} else {
index -= 1;
}
stop();
animate(divwidth);
showdata(index - 1);
showButton();
});
// 小圆点点击事件
buts.each(function () {
$(this).bind("click", function () {
// 判断当前是否在进行动画
if (list.is(":animated") || $(this).attr("class") == "on") {
return;
}
var myIndex = parseInt($(this).attr("index"));
if (myIndex == index) {
return;
}
//计算偏移量
var offset = (0 - divwidth) * (myIndex - index);
index = myIndex;
animates(offset);
// list.animate({ left: -360 });
showdata(index - 1);
showButton();
stop();
});
});
showdata(0);
container.hover(stop, play);
play();