WeChat Mini Programs Achieve Seamless Scrolling

WeChat Mini Programs Achieve Seamless Scrolling

This article example shares the specific code for WeChat applet to achieve seamless scrolling for your reference. The specific content is as follows

wxml

<view class="wrap-item" style='transform:translateX({{posLeft2}}px)'>
  <view class="messages-scroll firstScroll">
   <view class="{{index == 0?'yanse items':'items'}}" wx:for="{{zhuli}}" wx:key="index">
   <image wx:if="{{index == 0}}" src="../../images/xiangq_yonhu_icon_p.png"></image>
   <image wx:if="{{index != 0}}" src="../../images/xiangq_yonhu_icon_n.png"></image>
   <view>{{index}}{{item.ip}}{{item.str}}</view>
   </view>
  </view>

  <view class="messages-scroll secondScroll" style='transform:translateX({{marginLeft}}px)'>
   <view class="{{index == 0?'yanse items':'items'}}" wx:for="{{zhuli}}" wx:key="index">
   <image wx:if="{{index == 0}}" src="../../images/xiangq_yonhu_icon_p.png"></image>
   <image wx:if="{{index != 0}}" src="../../images/xiangq_yonhu_icon_n.png"></image>
   <view>{{item.ip}}{{item.str}}</view>
   </view>
  </view>
</view>

JS

onShow(){
let windowWidth = wx.getSystemInfoSync().windowWidth; //Screen width wx.createSelectorQuery().select('.firstScroll').boundingClientRect(function (rect) {
  let txtLength = rect.width; //text + icon length console.log(txtLength)
  console.log(rect)
  // that.setData({
  // marginLeft: txtLength < windowWidth - that.data.marginLeft ? windowWidth - txtLength : that.data.marginLeft
  // })
  console.log(that.data.marginLeft)
  that.roll2(that, txtLength, windowWidth); //Call the scroll method}).exec()
},

roll2: function (that, txtLength, windowWidth) {
 var interval2 = setInterval(function () {
 if (-that.data.posLeft2 < txtLength) {
 that.setData({
 posLeft2: that.data.posLeft2 - that.data.pace
 })
 } else { // The second paragraph scrolls to the left and then scrolls again that.setData({
 posLeft2: 0
 })
 clearInterval(interval2);
 that.roll2(that, txtLength, windowWidth);
 }
 }, 20)
},

wxss:

.wrap-item{
position: relative;
z-index: 10;
display: flex;
white-space: nowrap;
}

.brand-info .messages-scroll {
display: flex;
white-space: nowrap;

margin-top: 148rpx;
}

.brand-info .messages-scroll .items {
display: flex;
white-space: nowrap;
box-sizing: border-box;
padding: 0 10rpx;
margin-left: 10rpx;
align-items: center;
/* width: 332rpx; */
height: 50rpx;
background: rgba(0, 0, 0, 0.2);
border-radius: 25rpx;
color: #99A4BA;
}

.yanse{
color: #C4FFFD !important;
}

.brand-info .messages-scroll .items image {
width: 26rpx;
height: 22rpx;
margin-right: 10rpx;
}

.brand-info .messages-scroll .items view {
font-size: 24rpx;
font-family: Source Han Sans CN;
font-weight: 400;
}

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • WeChat applet implements a simple calculator
  • WeChat applet + mqtt, esp8266 temperature and humidity reading implementation method
  • WeChat applet custom scroll-view example code
  • WeChat applet to achieve the revolving lantern effect example
  • C language to achieve the whole process of recording the minesweeper game
  • Java simple game production code
  • Implementing a puzzle game with js
  • C# implements a simple flying chess game
  • Implementing the Snake Game in C Language under Linux
  • How to create WeChat games with CocosCreator

<<:  Methods to enhance access control security in Linux kernel

>>:  The difference between storing full-width characters and half-width characters in MySQL

Recommend

Teach you step by step to configure MySQL remote access

Preface When using the MySQL database, sometimes ...

Implementation of React virtual list

Table of contents 1. Background 2. What is a virt...

Introduction to the deletion process of B-tree

In the previous article https://www.jb51.net/arti...

30 Tips for Writing HTML Code

1. Always close HTML tags In the source code of p...

How to define data examples in Vue

Preface In the development process, defining vari...

Detailed explanation of HTML tables

Function: data display, table application scenari...

Install mysql5.7.17 using RPM under Linux

The installation method of MySQL5.7 rpm under Lin...

Two simple ways to remove text watermarks from web pages

<br /> When we browse certain websites and s...

Use ab tool to perform API stress test on the server

Table of contents 1 A brief introduction to syste...

Detailed explanation of psql database backup and recovery in docker

1. Postgres database backup in Docker Order: dock...

Detailed steps to install MySQL 5.7 via YUM on CentOS7

1. Go to the location where you want to store the...

Introduction to fourteen cases of SQL database

Data Sheet /* Navicat SQLite Data Transfer Source...

Detailed explanation of Vue router routing

Table of contents 1. Basic use 2. Several points ...

MySQL uses variables to implement various sorting

Core code -- Below I will demonstrate the impleme...