星火官网,前端页面(前台)
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

product.js 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. $(function () {
  2. $(".header_root").load("./comm/header.html");
  3. $(".footer_root").load("./comm/footer.html");
  4. // nav传值显示下划线
  5. $(".header_root").data("nav_info", 1);
  6. //获取元素
  7. var divheight = $(".exam_one").height();
  8. var container = $(".exam_container");
  9. var list = $(".show_exam");
  10. var buts = $(".exam_item");
  11. var index = 0; //存放当前显示的图片的下标
  12. var interval = 5000; //位移时间间隔
  13. var timer;
  14. function animate(offset) {
  15. var top = parseInt(list.css("top")) + offset;
  16. // console.log(list.css("top"));
  17. var absnum = Math.abs(offset);
  18. index++;
  19. // 边界判断
  20. // if (offset > 0) {
  21. // offset = "+=" + offset;
  22. // } else {
  23. // offset = "-=" + Math.abs(offset);
  24. // }
  25. offset = "-=" + Math.abs(offset);
  26. if (index == 5) {
  27. index = 0;
  28. offset = 0;
  29. }
  30. showButton();
  31. // console.log("当前索引", index, top, offset);
  32. list.animate({ top: offset }, 300, function () {
  33. if (top > -200) {
  34. }
  35. });
  36. }
  37. var imglist = [
  38. {
  39. blue: "../img/product/mtblue.png",
  40. grey: "../img/product/mtgrey.png"
  41. },
  42. {
  43. blue: "../img/product/zdblue.png",
  44. grey: "../img/product/zdgrey.png"
  45. },
  46. {
  47. blue: "../img/product/ydblue.png",
  48. grey: "../img/product/ydgrey.png"
  49. },
  50. {
  51. blue: "../img/product/yyblue.png",
  52. grey: "../img/product/yygrey.png"
  53. },
  54. {
  55. blue: "../img/product/sjblue.png",
  56. grey: "../img/product/sjgrey.png"
  57. }
  58. ];
  59. //亮起小圆点
  60. function showButton() {
  61. var html = "";
  62. buts.each(function (idx, item) {
  63. if (idx == index) {
  64. $(this).html(`<img src="${imglist[idx].blue}" />`);
  65. } else {
  66. $(this).html(`<img src="${imglist[idx].grey}" />`);
  67. }
  68. });
  69. }
  70. // 鼠标离开图片区域时,轮播继续
  71. function play() {
  72. timer = setTimeout(function () {
  73. animate(divheight);
  74. play();
  75. }, interval);
  76. }
  77. //鼠标进入图片区域时,停止轮播
  78. function stop() {
  79. if (timer) {
  80. clearTimeout(timer);
  81. timer = null;
  82. }
  83. }
  84. // 点击事件
  85. buts.each(function () {
  86. $(this).bind("click", function () {
  87. var myIndex = parseInt($(this).attr("index"));
  88. if (myIndex == index) {
  89. return;
  90. }
  91. index = myIndex;
  92. showButton();
  93. });
  94. });
  95. container.hover(stop, play);
  96. play();
  97. showButton();
  98. //楼梯导航
  99. $(window).on("scroll", function () {
  100. var $scroll = $(this).scrollTop();
  101. // 拖动滚轮,点亮对应的楼层标签
  102. $(".piece").each(function () {
  103. var $stepTop = $(".piece").eq($(this).index()).offset().top;
  104. // 楼层的top大于滚动条的距离
  105. if ($stepTop > $scroll) {
  106. $(".step").removeClass("active");
  107. $(".step").eq($(this).index()).addClass("active");
  108. // 中断循环
  109. return false;
  110. }
  111. });
  112. });
  113. // 获取每个楼梯的offset().top,点击楼层让对应的内容模块移动到对应的位置
  114. var $stepItem = $(".step");
  115. $stepItem.on("click", function () {
  116. $(this).addClass("active").siblings("li").removeClass("active");
  117. var $stepTop = $(".piece")
  118. .eq($(this).index() - 1)
  119. .offset().top;
  120. // 获取每个楼梯的offsetTop值
  121. $("html,body").animate({
  122. scrollTop: $stepTop
  123. });
  124. });
  125. // 回到顶部
  126. $(".top").on("click", function () {
  127. $("html,body").animate({
  128. scrollTop: 0
  129. });
  130. });
  131. });