Sample code for implementing horizontal infinite scrolling with pure CSS3

Sample code for implementing horizontal infinite scrolling with pure CSS3

The examples in this article are all written in small programs, but this does not affect the functions to be implemented.

wxml

Make one more copy of the box containing the picture so that the beginning and end of the looped picture are connected

<view class="scrollbox dis-flex">
    <view class="imgItem dis-flex" style="animation: {{computedAni}};">
      <image src="../img/{{index + 1}}.jpg" wx:for="{{images}}" mode="aspectFill" wx:key="index"></image>
    </view>
    <view class="imgItem dis-flex" style="animation: {{computedAni}};">
      <image src="../img/{{index + 1}}.jpg" wx:for="{{images}}" mode="aspectFill" wx:key="index"></image>
    </view>
</view>

wxss

.dis-flex {
  display: flex;
  display: -webkit-flex;
}
.scrollbox {
  margin: 30px;
  text-align: center;
  border: 1px solid blue;
  height: 220rpx;
  align-items: center;
  overflow: hidden;
}
.imgItem {
  animation: 24s rowup linear infinite normal;
}
.imgItem image {
  width: 200rpx;
  height: 200rpx;
  margin: 0 20rpx;
}
@keyframes rowup {
  0% {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
  }
  100% {
      -webkit-transform: translate3d(-100%, 0, 0);
      transform: translate3d(-100%, 0, 0);
  }
}
@-webkit-keyframes rowup {
  0% {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(-1000px, 0, 0);
    transform: translate3d(-1000px, 0, 0);
  }
}

js

The key to adjusting the speed is that the animation time is dynamically controlled by the number of looped items.

Page({
  data: {
    images: new Array(4),
    computedAni: ''
  },
  onLoad: function () {
    this.setAniSpeed(this.data.images.length)
  },
  setAniSpeed(num) {
    let time = Math.ceil(num / 5 * 15) // Here, the animation time is 15s when there are 5 pictures. You can adjust it yourself this.setData({
      computedAni: `${time}s rowup linear infinite normal`
    })
  }
})

Click here to view the code snippet

https://developers.weixin.qq.com/s/4gGngEm67Zlh

This concludes this article about the sample code for implementing horizontal infinite scrolling with pure CSS3. For more relevant CSS3 horizontal infinite scrolling content, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope you will support 123WORDPRESS.COM in the future!

<<:  Double loading issue when the page contains img src

>>:  How to use the href attribute of the HTML a tag to specify relative and absolute paths

Recommend

How to implement hot deployment and hot start in Eclipse/tomcat

1. Hot deployment: It means redeploying the entir...

Detailed explanation of the use of Linux seq command

01. Command Overview The seq command is used to g...

Regular expression usage in CSS selectors

Yes, CSS has regular expressions too (Amen) Two p...

Solution to the gap between divs

When you use HTML div blocks and the middle of th...

mysql8 Common Table Expression CTE usage example analysis

This article uses an example to describe how to u...

MySQL query method with multiple conditions

mysql query with multiple conditions Environment:...

Detailed explanation of HTML page header code example

Knowledge point 1: Set the base URL of the web pa...

Detailed explanation of the difference between $router and $route in Vue

We usually use routing in vue projects, and vue-r...

Detailed explanation of CSS sticky positioning position: sticky problem pit

Preface: position:sticky is a new attribute of CS...