WeChat applet implements text scrolling

WeChat applet implements text scrolling

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

wxml:

<view>After displaying, display again:</view>
<view class="example">
 <view class="box">
 <view class="text" style="{{orientation}}:{{marqueeDistance}}px;font-size: {{size}}px;">
  {{text}}
 </view>
 </view>
</view>
<view>When the white border appears, it will display:</view>
<view class="example">
 <view class="box">
 <view class="text" style="{{orientation}}:{{marqueeDistance2}}px;font-size: {{size}}px;">
  <text>{{text}}</text>
  <text wx:if="{{marquee2copy_status}}" style="margin-left:{{marquee2_margin}}px;">{{text}}</text>
 </view>
 </view>
</view>

wxss:

.example {
 display: block;
 width: 100%;
 height: 100rpx;
}

.box {
 width: 100%;
 position: relative;
}

.text {
 white-space: nowrap;
 position: absolute;
 top: 0;
}

js:

Page({


 data: {
 text: 'Scrolling text 1234567890abcdefghijklmnopqrstuvmxyz',
 marqueePace: 1, //Scrolling speed marqueeDistance: 0, //Initial scrolling distance marqueeDistance2: 0,
 marquee2copy_status: false,
 marquee2_margin: 60,
 size: 14,
 orientation: 'left', //Scroll direction interval: 20 // Time interval},
 onShow: function() {
 // Page display var vm = this;
 var length = vm.data.text.length * vm.data.size; //text length var windowWidth = wx.getSystemInfoSync().windowWidth; //screen width vm.setData({
  length: length,
  windowWidth: windowWidth,
  marquee2_margin: length < windowWidth ? windowWidth - length : vm.data.marquee2_margin //When the text length is shorter than the screen length, padding needs to be added});
 vm.run1(); //After scrolling a horizontal line of words, scroll in the original direction vm.run2(); //The first word disappears and then immediately appears from the right },
 run1: function() {
 var vm = this;
 var interval = setInterval(function() {
  if (-vm.data.marqueeDistance < vm.data.length) {
  vm.setData({
   marqueeDistance: vm.data.marqueeDistance - vm.data.marqueePace,
  });
  } else {
  clearInterval(interval);
  vm.setData({
   marqueeDistance: vm.data.windowWidth
  });
  vm.run1();
  }
 }, vm.data.interval);
 },
 run2: function() {
 var vm = this;
 var interval = setInterval(function() {
  if (-vm.data.marqueeDistance2 < vm.data.length) {
  // If the text scrolls to the white edge of marquee2_margin=30px, then display vm.setData({
   marqueeDistance2: vm.data.marqueeDistance2 - vm.data.marqueePace,
   marquee2copy_status: vm.data.length + vm.data.marqueeDistance2 <= vm.data.windowWidth + vm.data.marquee2_margin,
  });
  } else {
  if (-vm.data.marqueeDistance2 >= vm.data.marquee2_margin) { // When the second text scrolls to the leftmost vm.setData({
   marqueeDistance2: vm.data.marquee2_margin // re-roll directly });
   clearInterval(interval);
   vm.run2();
  } else {
   clearInterval(interval);
   vm.setData({
   marqueeDistance2: -vm.data.windowWidth
   });
   vm.run2();
  }
  }
 }, vm.data.interval);
 }


})

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 scroll-view hidden scroll bar detailed explanation
  • How to implement scroll penetration and prevent scrolling in WeChat applet scroll-view
  • Detailed explanation of the practical pitfalls of WeChat applet scroll-view horizontal scrolling and the implementation of hiding its scroll bar
  • WeChat applet top scrollable navigation effect
  • WeChat applet scroll-view component implements scrolling animation
  • WeChat applet-example code for scrolling message notification
  • WeChat applet scroll tab to achieve left and right sliding switching
  • WeChat applet realizes multi-line text scrolling effect
  • WeChat applet realizes horizontal and vertical scrolling
  • WeChat Mini Programs Achieve Seamless Scrolling

<<:  How to show or hide common icons on the desktop in Windows Server 2012

>>:  my.cnf parameter configuration to optimize InnoDB engine performance

Recommend

Why is UTF-8 not recommended in MySQL?

I recently encountered a bug where I was trying t...

Specific use of MySQL segmentation function substring()

There are four main MySQL string interception fun...

Docker uses busybox to create a base image

The first line of a Docker image starts with an i...

Vue implements table paging function

This article example shares the specific code of ...

MySQL 5.7.21 installation and password configuration tutorial

MySQL5.7.21 installation and password setting tut...

Flame animation implemented with CSS3

Achieve results Implementation Code html <div ...

In-depth study of MySQL multi-version concurrency control MVCC

MVCC MVCC (Multi-Version Concurrency Control) is ...

Detailed explanation of Vue custom instructions

Table of contents Vue custom directive Custom dir...

Implementation code of front-end HTML skin changing function

50 lines of code to change 5 skin colors, includi...

Detailed graphic explanation of how to use svg in vue3+vite project

Today, in the practice of vue3+vite project, when...

CentOS7 64-bit installation mysql graphic tutorial

Prerequisites for installing MySQL: Install CentO...

Summary of common optimization operations of MySQL database (experience sharing)

Preface For a data-centric application, the quali...

Linux server quick uninstall and install node environment (easy to get started)

1. Uninstall npm first sudo npm uninstall npm -g ...