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


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 相关文章推荐
Array对象方法参考
Oct 03 Javascript
Extjs Ajax 乱码问题解决方案
Apr 15 Javascript
JQuery 学习技巧总结
May 21 Javascript
jQuery使用动态渲染表单功能完成ajax文件下载
Jan 15 Javascript
js特殊字符转义介绍
Nov 05 Javascript
原生js实现fadein 和 fadeout淡入淡出效果
Jun 05 Javascript
关于Node.js中Buffer的一些你可能不知道的用法
Mar 28 Javascript
vue中如何引入jQuery和Bootstrap
Apr 10 jQuery
详解Angular路由 ng-route和ui-router的区别
May 22 Javascript
不使用 JS 匿名函数理由
Nov 17 Javascript
JS异步函数队列功能实例分析
Nov 28 Javascript
layer.prompt使文本框为空的情况下也能点击确定的方法
Sep 24 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
Function eregi is deprecated (解决方法)
2013/06/21 PHP
解析PHP中intval()等int转换时的意外异常情况
2013/06/21 PHP
轻松掌握php设计模式之访问者模式
2016/09/23 PHP
PHP空值检测函数与方法汇总
2017/11/19 PHP
深入认识javascript中的eval函数
2009/11/02 Javascript
jquery操作下拉列表、文本框、复选框、单选框集合(收藏)
2014/01/08 Javascript
ext中store.load跟store.reload的区别示例介绍
2014/06/17 Javascript
JavaScript中判断页面关闭、页面刷新的实现代码
2014/08/27 Javascript
jquery实现用户信息修改验证输入方法汇总
2015/07/18 Javascript
jQuery右下角旋转环状菜单特效代码
2015/08/10 Javascript
关注jquery技巧提高jquery技能(前端开发必学)
2015/11/02 Javascript
Bootstrap自动适应PC、平板、手机的Bootstrap栅格系统
2016/05/27 Javascript
JS触发服务器控件的单击事件(详解)
2016/08/06 Javascript
Angularjs 实现分页功能及示例代码
2016/09/14 Javascript
引入JavaScript时alert弹出框显示中文乱码问题
2017/09/16 Javascript
jQuery基于cookie实现换肤功能实例
2017/10/14 jQuery
PHP自动加载autoload和命名空间的应用小结
2017/12/01 Javascript
Vue仿支付宝支付功能
2018/05/25 Javascript
Vue组件创建和传值的方法
2018/08/17 Javascript
vue前后分离调起微信支付
2019/07/29 Javascript
区分vue-router的hash和history模式
2020/10/03 Javascript
jQuery实现本地存储
2020/12/22 jQuery
python实现二维数组的对角线遍历
2019/03/02 Python
Centos7下源码安装Python3 及shell 脚本自动安装Python3的教程
2020/03/07 Python
Python日志logging模块功能与用法详解
2020/04/09 Python
Opencv常见图像格式Data Type及代码实例
2020/11/02 Python
解决pytorch下出现multi-target not supported at的一种可能原因
2021/02/06 Python
css3实现平移效果(transfrom:translate)的示例
2020/11/13 HTML / CSS
澳大利亚的奢侈品牌:Oroton
2016/08/26 全球购物
德国婴儿推车和儿童安全座椅商店:BABYSHOP
2016/09/01 全球购物
历史系自荐信范文
2013/12/24 职场文书
小学生演讲稿大全
2014/04/25 职场文书
重阳节活动主持词
2015/07/04 职场文书
2015年医院保卫科工作总结
2015/07/23 职场文书
导游词之河北邯郸
2019/09/12 职场文书
MySQL数据库查询之多表查询总结
2022/08/05 MySQL