网页版

  1. window.onload = function load(){
  2. // 左右箭头设置,鼠标放上来才会出现, 离开就消失
  3. let focus = document.querySelector('.focus');
  4. let arrow1 = document.querySelector('.arrow-l');
  5. let arrow2 = document.querySelector('.arrow-r');
  6. focus.addEventListener('mouseenter',function() {
  7. arrow1.style.display = 'block';
  8. arrow2.style.display = 'block';
  9. })
  10. focus.addEventListener('mouseleave',function() {
  11. arrow1.style.display = 'none';
  12. arrow2.style.display = 'none';
  13. })
  14. // 自动根据图片数量生成对应的小圆圈 + 点击小圆圈时候变色和移动
  15. var ul = focus.querySelector('ul');
  16. var ol = focus.querySelector('.circle');
  17. for(let i = 0;i<ul.children.length;i++) {
  18. let li = document.createElement('li');
  19. // 记录当前小圆圈的索引号
  20. li.setAttribute('index',i);
  21. ol.appendChild(li);
  22. ol.children[0].className = 'current';
  23. li.addEventListener('click',function() {
  24. for(let j = 0;j<ol.children.length;j++) {
  25. ol.children[j].className='';
  26. }
  27. this.className = 'current';
  28. // move my pic
  29. // 获取当前的索引号
  30. let index = this.getAttribute('index');
  31. // 当我们点击了某个小li,就应该把这个索引号给cnt
  32. cnt = index;
  33. let focusWidth = focus.offsetWidth;
  34. animate(ul,-index*focusWidth);
  35. })
  36. }
  37. // 无缝滚动
  38. let fir = ul.children[0].cloneNode(true);
  39. // 深克隆
  40. ul.appendChild(fir);
  41. // 点击箭头,图片进行滚动
  42. let cnt = 0 ;
  43. // 节流阀
  44. let flag = true;
  45. let focusWidth = focus.offsetWidth;
  46. arrow1.addEventListener('click',function(){
  47. if(flag) {
  48. cnt--;
  49. if(cnt < 0) {
  50. cnt = ol.children.length - 1;
  51. ul.style.left = -cnt *focusWidth +'px';
  52. }
  53. animate(ul,-cnt*focusWidth,function() {
  54. flag = true;
  55. });
  56. circleChange(cnt);
  57. }
  58. })
  59. arrow2.addEventListener('click',function(){
  60. if(flag) {
  61. flag = false;
  62. cnt++;
  63. // 当遍历到最后一张图片时自动跳转到最前面
  64. if(cnt == ul.children.length - 1) {
  65. ul.style.left = 0;
  66. cnt = 0;
  67. ol.children[0].className = 'current';
  68. }
  69. animate(ul,-cnt*focusWidth,function() {
  70. flag = true;
  71. });
  72. circleChange(cnt);
  73. }
  74. })
  75. function circleChange(cnt) {
  76. for(let j = 0;j<ol.children.length;j++) {
  77. ol.children[j].className = '';
  78. }
  79. ol.children[cnt].className = 'current';
  80. }
  81. // 自动播放,手动调用点击事件
  82. let timer = setInterval(function() {
  83. arrow2.click();
  84. },2000)
  85. }
  1. function animate(obj, target, callback) {
  2. clearInterval(obj.timer);
  3. obj.timer = setInterval(function() {
  4. let step = (target - obj.offsetLeft) / 10;
  5. step = step > 0 ? Math.ceil(step) : Math.floor(step);
  6. if (obj.offsetLeft == target) {
  7. // 停止动画 本质是停止定时器
  8. clearInterval(obj.timer);
  9. callback && callback();
  10. }
  11. // 把每次加1 这个步长值改为一个慢慢变小的值 步长公式:(目标值 - 现在的位置) / 10
  12. obj.style.left = obj.offsetLeft + step + 'px';
  13. }, 15);
  14. }

移动端版

  1. window.addEventListener('load', function() {
  2. // alert(1);
  3. // 1. 获取元素
  4. var focus = document.querySelector('.focus');
  5. var ul = focus.children[0]; // 将包裹图片的ul获取
  6. // 获得focus 的宽度
  7. var w = focus.offsetWidth;
  8. var ol = focus.children[1]; // 将包裹点点的ol获取
  9. // 2. 利用定时器自动轮播图图片
  10. var index = 0;
  11. var timer = setInterval(function() {
  12. index++;
  13. var translatex = -index * w;
  14. // 过度属性
  15. ul.style.transition = 'all .3s';
  16. ul.style.transform = 'translateX(' + translatex + 'px)';
  17. }, 2000);
  18. // 等着我们过渡完成之后,再去判断 监听过渡完成的事件 transitionend
  19. ul.addEventListener('transitionend', function() {
  20. // 无缝滚动
  21. if (index >= 3) {
  22. index = 0;
  23. // 去掉过渡效果 这样让我们的ul 快速的跳到目标位置
  24. ul.style.transition = 'none';
  25. // 利用最新的索引号乘以宽度 去滚动图片
  26. var translatex = -index * w;
  27. ul.style.transform = 'translateX(' + translatex + 'px)';
  28. } else if (index < 0) {
  29. index = 2;
  30. // 去掉过渡效果
  31. ul.style.transition = 'none';
  32. // 利用最新的索引号乘以宽度 去滚动图片
  33. var translatex = -index * w;
  34. ul.style.transform = 'translateX(' + translatex + 'px)';
  35. }
  36. // 3. 小圆点跟随变化
  37. // 把ol里面li带有current类名的选出来去掉类名 remove
  38. ol.querySelector('.current').classList.remove('current');
  39. // 让当前索引号 的小li 加上 current add
  40. ol.children[index].classList.add('current');
  41. });
  42. // 4. 手指滑动轮播图
  43. // 触摸元素 touchstart: 获取手指初始坐标
  44. var startX = 0;
  45. var moveX = 0; // 后面我们会使用这个移动距离所以要定义一个全局变量
  46. var flag = false; // 记录手指是否有过移动
  47. ul.addEventListener('touchstart', function(e) {
  48. startX = e.targetTouches[0].pageX;
  49. // 手指触摸的时候就停止定时器
  50. clearInterval(timer);
  51. });
  52. // 移动手指 touchmove: 计算手指的滑动距离, 并且移动盒子
  53. ul.addEventListener('touchmove', function(e) {
  54. // 计算移动距离
  55. moveX = e.targetTouches[0].pageX - startX;
  56. // 移动盒子: 盒子原来的位置 + 手指移动的距离
  57. var translatex = -index * w + moveX;
  58. // 手指拖动的时候,不需要动画效果所以要取消过渡效果
  59. ul.style.transition = 'none';
  60. ul.style.transform = 'translateX(' + translatex + 'px)';
  61. flag = true; // 如果用户手指移动过我们再去判断否则不做判断效果
  62. e.preventDefault(); // 阻止滚动屏幕的行为
  63. });
  64. // 手指离开 根据移动距离去判断是回弹还是播放上一张下一张
  65. ul.addEventListener('touchend', function(e) {
  66. if (flag) {
  67. // (1) 如果移动距离大于50像素我们就播放上一张或者下一张
  68. if (Math.abs(moveX) > 50) {
  69. // 如果是右滑就是 播放上一张 moveX 是正值
  70. if (moveX > 0) {
  71. index--;
  72. } else {
  73. // 如果是左滑就是 播放下一张 moveX 是负值
  74. index++;
  75. }
  76. var translatex = -index * w;
  77. ul.style.transition = 'all .3s';
  78. ul.style.transform = 'translateX(' + translatex + 'px)';
  79. } else {
  80. // (2) 如果移动距离小于50像素我们就回弹
  81. var translatex = -index * w;
  82. ul.style.transition = 'all .1s';
  83. ul.style.transform = 'translateX(' + translatex + 'px)';
  84. }
  85. }
  86. // 手指离开的时候就重新开启定时器
  87. clearInterval(timer);
  88. timer = setInterval(function() {
  89. index++;
  90. var translatex = -index * w;
  91. ul.style.transition = 'all .3s';
  92. ul.style.transform = 'translateX(' + translatex + 'px)';
  93. }, 2000);
  94. });
  95. // 返回顶部模块制作
  96. var goBack = document.querySelector('.goBack');
  97. var nav = document.querySelector('nav');
  98. window.addEventListener('scroll', function() {
  99. if (window.pageYOffset >= nav.offsetTop) {
  100. goBack.style.display = 'block';
  101. } else {
  102. goBack.style.display = 'none';
  103. }
  104. });
  105. goBack.addEventListener('click', function() {
  106. window.scroll(0, 0);
  107. })
  108. })