其他分享
首页 > 其他分享> > 实现起点无限轮播列表

实现起点无限轮播列表

作者:互联网

 

 

 逛起点的时候看到这个效果,想着自己也写一下。

实现这个效果主要思路是在行内样式中添加所需的图片,给三个li定位。在初始化的时候获取每个li的样式,用setInterval无限循环,每次把样式数组第一项移至最后一项,渲染。

首先完成html

  <div class="container">
    <ul class="roundabout">
      <li class="left">
        <img src="https://bookcover.yuewen.com/qdbimg/349573/1031527480/90" alt="">
      </li>
      <li class="center">
        <img src="https://bookcover.yuewen.com/qdbimg/349573/1028491679/90" alt="">
      </li>
      <li class="right">
        <img src="https://bookcover.yuewen.com/qdbimg/349573/1016735308/90" alt="">
      </li>
    </ul>
  </div>

样式参考起点

<style>
    li, ol, ul {
      list-style: none outside none;
    }
    .container {
      position: relative;
      z-index: 1;
      height: 112px;
      margin-bottom: 10px;
      padding: 16px 0 0 48px;
    }
    .roundabout {
      position: relative;
      display: block;
      padding: 0px;
    }
    .roundabout li {
      cursor: pointer;
      box-shadow: 0 1px 8px #7f7f7f;
    }
    .roundabout li img {
      display: inline;
      width: 100%;
      height: 100%;
    }
    .left {
      position: absolute;
      left: -18px;
      top: 0px;
      width: 64.638px;
      height: 86.184px;
      opacity: 0.85;
      z-index: 142;
      font-size: 12.3px;
    }
    .center {
      position: absolute;
      left: 16px;
      top: -13px;
      width: 83.9916px;
      height: 111.989px;
      opacity: 1;
      z-index: 280;
      font-size: 16px;
    }
    .right {
      position: absolute;
      left: 75px;
      top: -1px;
      width: 65.5788px;
      height: 87.4384px;
      opacity: 0.85;
      z-index: 148;
      font-size: 12.5px;
    }
  </style>

完成后为

 

 

 现在开始写js逻辑

<script>
  +function() {
    const allItems = document.querySelector('.roundabout').children,
        classNames = []
    // 初始化
    const init = () => {
      Array.from(allItems).map(item => classNames.push(item.className))
      console.log(classNames);
      autoRoundAbout()
    }
    // 设置无限循环
    const autoRoundAbout = () => {
      setInterval(setClassName, 3000)
    }
    // 将class列表向左移一位
    const setClassName = () => {
      classNames.unshift(classNames.pop())
      render()
    }
    // 重新渲染给li添加class
    const render = () => {
      for(let i = 0; i < allItems.length; i++) {
        allItems[i].className = classNames[i]
      }
    }

    init()
  }()
</script>

现在已经完成了自动循环,再给li上加个过渡效果,就完成了基本滚动。

然后在给ul添加事件委托,判断左右两侧添加点击事件。

标签:const,轮播,px,li,height,classNames,position,列表,起点
来源: https://www.cnblogs.com/bobkang/p/15857905.html