微信小程序实现走马灯效果实例

 更新时间:2021年03月17日 09:22:19   作者:程序猿tx  
这篇文章主要给大家介绍了关于微信小程序实现走马灯效果的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

日常开发中,我们经常会遇到文字横向循环滚动的效果,俗称走马灯,也是项目中经常会使用的一个功能。在网页web前端很常见,今天就介绍下小程序的实现方式,一种是用的css样式实现,另一种是运用小程序的动画功能实现。

@keyframes 实现

利用@keyframes的规则来实现,非常方便,只需要css样式就可以满足,使用方法跟web上一样。

<view class="marquee">
 <text>这是一段滚动的文字</text>
</view>

样式类,from to 来定义动画的开始结束,这里是从屏幕最右端向左滑,触及到最左侧后重新开始新一轮动画。

@keyframes translation {
 from {
 margin-left: 750rpx; //从屏幕最右端开始
 }

 to {
 margin-left: 0px;
 }
}

.marquee{
 white-space: nowrap;
 animation-name: translation; //定义动画的名称
 animation-duration: 3s;
 animation-iteration-count: infinite;
 animation-timing-function: linear;
}

如果想要的效果是滑动到左侧之后,文字继续左滑,直到全部消失,再从最右开始动画的,那么就需要再加上文字的长度,这里需要去计算文字的长度,使用SelectorQuery 对象实例来拿到文字节点的宽度。在页面首次渲染完毕onReady时执行,查询到对应文字节点信息的对象,得到文字的长度。这里定义的是上面的marquee类名。

onReady: function () {
 let query = wx.createSelectorQuery();
 query.select('.marquee').boundingClientRect();
 query.exec((res) => {
  if (res[0]) {
  this.setData({
   marqueeWidth: res[0].width
  })
  }
 })
}

然后使用css var() 函数插入定义的属性值,到结束的位置处,让它走完整个屏幕以及自身文字的长度。定义一个名为 "--marqueeWidth" 的属性,然后在wxss样式文件里使用var()函数调用该属性:

<view class="marquee" style="--marqueeWidth:-{{marqueeWidth}}px">
 <text>这是一段滚动的文字</text>
</view>

wxss样式里:
@keyframes translation {
 from {
 margin-left: 750rpx;
 }

 to {
 margin-left: var(--marqueeWidth);
 }
}

这是通过css的方式实现的,非常方便,但是会出现在部分机型上适配的问题,还有一种是通过Animation动画实现。

animation实现

通过animation动画实例来完成动画,一开始让视图位于屏幕右侧超出屏幕的。

<view class="marquee2" bindtransitionend="animationend" animation="{{animationData}}">
	<text>这是一段滚动的文字</text>
</view>

.marquee2{
 display: inline-block;
 white-space: nowrap;
 margin-left: 750rpx;
}

同样这里计算了文字的长度,通过Animation.translate(number tx, number ty)平移属性进行移动操作,直至移出整个屏幕。在一组动画完成之后,调用bindtransitionend回调,再一次去执行动画,

this.animation = wx.createAnimation({
 duration: 3000,
 timingFunction: 'linear'
});
var query = wx.createSelectorQuery();
query.select('.marquee2').boundingClientRect();
query.exec((res) => {
 if (res[0]) {
 this.setData({
  marqueeWidth: res[0].width //文字长度
 }, () => {
  this.doAnim()
 })
 }
})


doAnim: function () {
 //向左滚动到超出屏幕,这里临时写死的屏幕宽度375px
 this.animation.translate(-this.data.marqueeWidth - 375, 0).step();
 setTimeout(() => {
  this.setData({
  animationData: this.animation.export(),
  });
 }, 10)
}

在第一次动画结束之后,重新开始,通过animationend监听动画结束,然后再次执行。

animationend() {
 //复位
 this.animation.translate(0, 0).step({ duration: 0 });
 this.setData({
  animationData: this.animation.export()
 }, () => {
  //重新开始动画
  this.doAnim()
 });
}

这个动画在小程序开发工具上运行会有动画突然暂停的现象,可以用手机试下的。

相对而言是比较容易实现的,而且走马灯的效果也是我们在项目中经常会用到的,正好也可以熟悉下小程序的动画的。

总结

到此这篇关于微信小程序实现走马灯效果实例的文章就介绍到这了,更多相关小程序走马灯效果内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 原生JS实现实时钟表

    原生JS实现实时钟表

    这篇文章主要为大家详细介绍了原生JS实现实时钟表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • JavaScript DOM节点操作方式全面讲解

    JavaScript DOM节点操作方式全面讲解

    DOM(Document Object Model 文档对象模型)定义了访问和操作文档的标准方法。整个浏览器网页就是一个Dom树形结构,这篇文章主要介绍了JavaScript DOM节点操作方式
    2022-10-10
  • javascript 跨浏览器开发经验总结(五) js 事件

    javascript 跨浏览器开发经验总结(五) js 事件

    javascript 跨浏览器开发之js 事件的兼容性问题,需要的朋友可以参考下。
    2010-05-05
  • JavaScript File分段上传

    JavaScript File分段上传

    这篇文章主要介绍了JavaScript File分段上传的相关资料,需要的朋友可以参考下
    2016-03-03
  • 微信小程序实现发红包功能

    微信小程序实现发红包功能

    这篇文章主要为大家详细介绍了微信小程序实现发红包功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • js实现响应按钮点击弹出可拖拽的非模态对话框完整实例【测试可用】

    js实现响应按钮点击弹出可拖拽的非模态对话框完整实例【测试可用】

    这篇文章主要介绍了js实现响应按钮点击弹出可拖拽的非模态对话框,结合完整实例形式分析了原生JavaScript实现的可拖拽非模态对话框实现技巧与使用方法,需要的朋友可以参考下
    2023-04-04
  • JavaScript利用虚拟列表实现高性能渲染数据详解

    JavaScript利用虚拟列表实现高性能渲染数据详解

    在前文中我们提到可以使用时间分片的方式来对长列表进行渲染,但这种方式更适用于列表项的DOM结构十分简单的情况,所以本文来讲讲如何使用虚拟列表的方式,来同时加载大量数据吧
    2023-05-05
  • tsc性能优化Project References使用详解

    tsc性能优化Project References使用详解

    这篇文章主要为大家介绍了tsc性能优化Project References使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • JavaScript进制数之间的互相转换

    JavaScript进制数之间的互相转换

    这篇文章主要介绍了JavaScript进制数之间的互相转换,进制转换是人们利用符号来计数的方法,下文基于JavaScript实现进制数之间的转换,有一定的知识性参考价值,需要的小伙伴可以参考一下
    2022-05-05
  • JS实现视频弹幕效果

    JS实现视频弹幕效果

    这篇文章主要为大家详细介绍了JS实现视频弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论