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


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 相关文章推荐
javascript实现上传图片前的预览(TX的面试题)
Aug 20 Javascript
DOM Scripting中的图片切换[兼容Firefox]
Jun 12 Javascript
jQuery随机切换图片的小例子
Apr 18 Javascript
jquery实现input输入框实时输入触发事件代码
Jan 28 Javascript
JavaScript数字和字符串转换示例
Mar 26 Javascript
javaScript实现滚动新闻的方法
Jul 30 Javascript
从源码看angular/material2 中 dialog模块的实现方法
Oct 18 Javascript
Vue+Vux项目实践完整代码
Nov 30 Javascript
详解Angular调试技巧之报错404(not found)
Jan 31 Javascript
vue2.0使用swiper组件实现轮播的示例代码
Mar 03 Javascript
5分钟快速看懂ES6中的反射与代理
Dec 19 Javascript
通过vue.extend实现消息提示弹框的方法记录
Jan 07 Vue.js
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
延长phpmyadmin登录时间的方法
2011/02/06 PHP
用php解析html的实现代码
2011/08/08 PHP
gd库图片下载类实现下载网页所有图片的php代码
2012/08/20 PHP
php使用ICQ网关发送手机短信
2013/10/30 PHP
浅析php中json_encode()和json_decode()
2014/05/25 PHP
PHP接口并发测试的方法(推荐)
2016/12/15 PHP
js实现ASP分页函数 HTML分页函数
2006/09/22 Javascript
一个对于js this关键字的问题
2007/01/09 Javascript
Javascript 个人笔记(没有整理,很乱)
2007/07/07 Javascript
js 操作符汇总
2014/11/08 Javascript
jQuery中before()方法用法实例
2014/12/25 Javascript
使用Chart.js图表库制作漂亮的响应式表单
2015/10/28 Javascript
基于jquery插件实现拖拽删除图片功能
2020/08/27 Javascript
javascript如何创建对象
2016/08/29 Javascript
JS点击某个图标或按钮弹出文件选择框的实现代码
2016/09/27 Javascript
javascript 注释代码的几种方法总结
2017/01/04 Javascript
利用require.js与angular搭建spa应用的方法实例
2017/07/19 Javascript
vue添加class样式实例讲解
2019/02/12 Javascript
快速了解Node中的Stream流是什么
2019/02/13 Javascript
Vue实现一个图片懒加载插件
2019/03/11 Javascript
JavaScript动画实例之粒子文本的实现方法详解
2020/07/28 Javascript
Vue实现简易购物车页面
2020/12/30 Vue.js
python中私有函数调用方法解密
2016/04/29 Python
python中使用%与.format格式化文本方法解析
2017/12/27 Python
一份python入门应该看的学习资料
2018/04/11 Python
PyQt5实现简单数据标注工具
2019/03/18 Python
Python中捕获键盘的方式详解
2019/03/28 Python
Python实现将HTML转成PDF的方法分析
2019/05/04 Python
django如何自己创建一个中间件
2019/07/24 Python
Pycharm连接远程服务器过程图解
2020/04/30 Python
新西兰最大的在线设计师眼镜店:SmartBuyGlasses新西兰
2017/10/20 全球购物
override和overload的区别
2016/03/09 面试题
建议书标准格式
2014/03/12 职场文书
马丁路德金演讲稿
2014/05/19 职场文书
云冈石窟导游词
2015/02/04 职场文书
2017年寒假少先队活动总结
2016/04/06 职场文书