微信小程序实现文字从右向左无限滚动


Posted in Javascript onNovember 18, 2020

本文实例为大家分享了微信小程序实现文字无限滚动的具体代码,供大家参考,具体内容如下

微信小程序实现文字从右向左无限滚动

布局页面wxml

<scroll-view class="container">
 <view class="scrolltxt">
 <view class="marquee_box">
  <view class="marquee_text" style="transform: translateX(-{{marqueeDistance}}px)">
  <text>{{text}}</text>
  <text style="margin-right:{{marquee_margin}}px;"></text>
  <text style="margin-right:{{marquee_margin}}px;">{{text}}</text>  
  </view>
 </view>
 </view>
</scroll-view>

样式页面 wxss

.container {height: 100%;display: flex;flex-direction: column;justify-content: space-between;box-sizing: border-box;}
.scrolltxt{padding:0 20rpx;background:#f8f8f8;}
.marquee_box {position:relative;color:#333;height:90rpx;display:block;overflow:hidden;} 
.marquee_text {white-space: nowrap;position:absolute;top:0;font-size:14px;height:90rpx;line-height:90rpx;}

小程序 js页面

Page({
 /**
 * 页面的初始数据
 * Linyufan.com
 */
 data: {
 text: "这是一条测试公告,看看效果怎么样,2019年3月23日",
 marqueePace: 1,//滚动速度
 marqueeDistance: 0,//初始滚动距离
 marquee_margin: 30,
 size:14,
 interval: 20 // 时间间隔
 },
 
 /**
 * 生命周期函数--监听页面加载
 */
 onLoad: function (options) { 
 },
 onShow: function () {
 var that = this;
 var length = that.data.text.length * that.data.size;//文字长度
 var windowWidth = wx.getSystemInfoSync().windowWidth;// 屏幕宽度
 //console.log(length,windowWidth);
 that.setData({
  length: length,
  windowWidth: windowWidth
 });
 that.scrolltxt();// 第一个字消失后立即从右边出现
 },
 
 scrolltxt: function () {
 var that = this;
 var length = that.data.length;//滚动文字的宽度
 var windowWidth = that.data.windowWidth;//屏幕宽度
 if (length > windowWidth){
  var interval = setInterval(function () {
  var maxscrollwidth = length + that.data.marquee_margin;//滚动的最大宽度,文字宽度+间距,如果需要一行文字滚完后再显示第二行可以修改marquee_margin值等于windowWidth即可
  var crentleft = that.data.marqueeDistance;
  if (crentleft < maxscrollwidth) {//判断是否滚动到最大宽度
   that.setData({
   marqueeDistance: crentleft + that.data.marqueePace
   })
  }
  else {
   //console.log("替换");
   that.setData({
   marqueeDistance: 0 // 直接重新滚动
   });
   clearInterval(interval);
   that.scrolltxt();
  }
  }, that.data.interval);
 }
 else{
  that.setData({ marquee_margin:"1000"});//只显示一条不滚动右边间距加大,防止重复显示
 } 
 }
})

为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于jQuery中的end()使用方法
Jul 10 Javascript
javascript的alert box在java中如何显示多行
May 18 Javascript
IE8中使用javascript动态加载CSS的解决方法
Jun 17 Javascript
Javascript闭包用法实例分析
Jan 23 Javascript
深入理解选择框脚本[推荐]
Dec 13 Javascript
微信小程序 Button 组件详解及简单实例
Jan 10 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
Jul 12 Javascript
AngularJS实现的生成随机数与猜数字大小功能示例
Dec 25 Javascript
vue单页面应用打开新窗口显示跳转页面的实例
Sep 21 Javascript
vue: WebStorm设置快速编译运行的方法
Oct 18 Javascript
Vue中通过Vue.extend动态创建实例的方法
Aug 13 Javascript
Vue 实现创建全局组件,并且使用Vue.use() 载入方式
Aug 11 Javascript
angular4自定义组件非input元素实现ngModel双向数据绑定的方法
Dec 28 #Javascript
小程序文字跑马灯效果
Dec 28 #Javascript
JS实现的图片选择顺序切换和循环切换功能示例【测试可用】
Dec 28 #Javascript
Angular使用Restful的增删改
Dec 28 #Javascript
原生js实现公告滚动效果
Jan 10 #Javascript
微信小程序实现文字无限轮播效果
Dec 28 #Javascript
小程序实现左右来回滚动字幕效果
Dec 28 #Javascript
You might like
超级实用的7个PHP代码片段分享
2012/01/05 PHP
教你如何使用php session
2013/10/28 PHP
PHP中mysqli_affected_rows作用行数返回值分析
2014/12/26 PHP
Zend Framework教程之资源(Resources)用法实例详解
2016/03/14 PHP
浅谈PHP中的面向对象OOP中的魔术方法
2017/06/12 PHP
Laravel框架分页实现方法分析
2018/06/12 PHP
javascript让setInteval里的函数参数中的this指向特定的对象
2010/01/31 Javascript
关于js中alert弹出窗口文本换行问题简单详细说明
2012/12/11 Javascript
js jquery获取随机生成id的服务器控件的三种方法
2013/07/11 Javascript
js调出上下文菜单的实例
2015/12/17 Javascript
微信小程序request请求后台接口php的实例详解
2017/09/20 Javascript
Bootstrap 3多级下拉菜单实例
2017/11/23 Javascript
浅谈node中的cluster集群
2018/06/02 Javascript
vue脚手架搭建项目的兼容性配置详解
2018/07/17 Javascript
JavaScript实现JSON合并操作示例【递归深度合并】
2018/09/07 Javascript
JavaScript中.min.js和.js文件的区别讲解
2019/02/13 Javascript
Bootstrap table 实现树形表格联动选中联动取消功能
2019/09/30 Javascript
vue中beforeRouteLeave实现页面回退不刷新的示例代码
2019/11/01 Javascript
easyUI使用分页过滤器对数据进行分页操作实例分析
2020/06/01 Javascript
Ubuntu 14.04+Django 1.7.1+Nginx+uwsgi部署教程
2014/11/18 Python
对python操作kafka写入json数据的简单demo分享
2018/12/27 Python
Python实现Event回调机制的方法
2019/02/13 Python
Python flask框架如何显示图像到web页面
2020/06/03 Python
python如何删除文件、目录
2020/06/23 Python
Django中F函数的使用示例代码详解
2020/07/06 Python
Python自动化之UnitTest框架实战记录
2020/09/08 Python
Python爬虫教程知识点总结
2020/10/19 Python
python中remove函数的踩坑记录
2021/01/04 Python
Html5剪切板功能的实现代码
2018/06/29 HTML / CSS
HTML5 embed标签定义和用法详解
2014/05/09 HTML / CSS
英语自荐信常用语句
2013/12/13 职场文书
小学毕业感言150字
2014/02/05 职场文书
地理信息科学专业推荐信
2014/09/08 职场文书
2014年行政工作总结
2014/11/19 职场文书
Redis的字符串是如何实现的
2021/10/24 Redis
WINDOWS 64位 下安装配置mysql8.0.25最详细的教程
2022/03/22 MySQL