微信小程序实现多行文字滚动


Posted in Javascript onNovember 18, 2020

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

微信小程序实现多行文字滚动

wxml

<view class="full" style="height:100%;overflow:hidden">
  <swiper autoplay="true" interval="3000" duration="500" circular="true" vertical="true" style="height:100%">
  <swiper-item wx:for="{{topnewslist}}" wx:key="{{index}}" catchtouchmove='catchTouchMove'>
   <van-notice-bar scrollable="{{false}}" bindtap="tonewsdetail" wx:for="{{item}}" wx:for-item="it" wx:key="{{index}}" data-newsid="{{it.new_id}}" style="width:100%" text="{{it.new_topic}}" />
  </swiper-item>
  </swiper>
</view>

wxss

swiper-item {
 height: 100%;
}

js

//index.js
//获取应用实例
import api from "../../utils/api.js"
var token = ''
const app = getApp()

Page({
 data: {
 topnewslist:[]
 },
 onLoad: function () {
 },
 tonewsdetail(e){
 var newsid=e.currentTarget.dataset.newsid;
 wx.navigateTo({
  url: '/pages/newsdetail/newsdetail?newsid='+newsid,
 })
 },

 loadscrollnews(){
 api.get("mpapi/mpmnews.ashx", { action:'toplist',token:token}).then((res)=>{
  if(res.code==1){
  //res.list=[{"new_id":1,"new_topic":"111"},{"new_id":2,"new_topic":"222"},{"new_id":3,"new_topic":"333"},{"new_id":4,"new_topic":"444"}]
  this.setData({
   topnewslist: this.splitArr(res.list, 2) //调用
   //调用之后[[{"new_id":1,"new_topic":"111"},{"new_id":2,"new_topic":"222"}],[{"new_id":3,"new_topic":"333"},{"new_id":4,"new_topic":"444"}]]
  })
  }
 })
 },
 /**
 * 分割数组创建二维数组封装
 * @param data 数组
 * @param senArrLen 需要分割成子数组的长度
 */
 splitArr(data, senArrLen){
 //处理成len个一组的数据
 let data_len = data.length;
 let arrOuter_len = data_len % senArrLen === 0 ? data_len / senArrLen : parseInt((data_len / senArrLen) + '') + 1;
 let arrSec_len = data_len > senArrLen ? senArrLen : data_len;//内层数组的长度
 let arrOuter = new Array(arrOuter_len);//最外层数组
 let arrOuter_index = 0;//外层数组的子元素下标
 // console.log(data_len % len);
 for (let i = 0; i < data_len; i++) {
  if (i % senArrLen === 0) {
  arrOuter_index++;
  let len = arrSec_len * arrOuter_index;
  //将内层数组的长度最小取决于数据长度对len取余,平时最内层由下面赋值决定
  arrOuter[arrOuter_index - 1] = new Array(data_len % senArrLen);
  if (arrOuter_index === arrOuter_len)//最后一组
   data_len % senArrLen === 0 ?
   len = data_len % senArrLen + senArrLen * arrOuter_index :
   len = data_len % senArrLen + senArrLen * (arrOuter_index - 1);
  let arrSec_index = 0;//第二层数组的索引
  for (let k = i; k < len; k++) {//第一层数组的开始取决于第二层数组长度*当前第一层的索引
   arrOuter[arrOuter_index - 1][arrSec_index] = data[k];
   arrSec_index++;
  }
  }
 }
 return arrOuter
 },
 // 截获竖向滑动
 catchTouchMove: function (res) {
 return false
 },
})

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

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

Javascript 相关文章推荐
JavaScript版代码高亮
Jun 26 Javascript
JS 文字符串转换unicode编码函数
May 30 Javascript
jQuery EasyUI API 中文文档 - TimeSpinner时间微调器
Oct 23 Javascript
Node.js与PHP、Python的字符处理性能对比
Jul 06 Javascript
JavaScript获取并更改input标签name属性的方法
Jul 02 Javascript
解析jQueryEasyUI的使用
Nov 22 Javascript
ionic实现底部分享功能
May 11 Javascript
关于vue.js v-bind 的一些理解和思考
Jun 06 Javascript
javascript 开发之网页兼容各种浏览器
Sep 28 Javascript
js动态设置select下拉菜单的默认选中项实例
Aug 21 Javascript
微信小程序实现banner图轮播效果
Jun 28 Javascript
javascript执行上下文、变量对象实例分析
Apr 25 Javascript
微信小程序实现自定义底部导航
Nov 18 #Javascript
微信小程序绘制半圆(弧形)进度条
Nov 18 #Javascript
微信小程序实现加入购物车滑动轨迹
Nov 18 #Javascript
Map与WeakMap类型在JavaScript中的使用详解
Nov 18 #Javascript
解决js中的setInterval清空定时器不管用问题
Nov 17 #Javascript
springboot+vue实现文件上传下载
Nov 17 #Vue.js
vue 表单输入框不支持focus及blur事件的解决方案
Nov 17 #Vue.js
You might like
PHP学习笔记 (1) 环境配置与代码调试
2011/06/19 PHP
PHP获取MAC地址的函数代码
2011/09/11 PHP
php获取从html表单传递数组的方法
2015/03/20 PHP
Yii框架页面渲染操作实例详解
2019/07/19 PHP
PHP7数组的底层实现示例
2019/08/25 PHP
JavaScript中的null和undefined解析
2012/04/14 Javascript
jQuery图片轮播的具体实现
2013/09/11 Javascript
jQuery中获取checkbox选中项等操作及注意事项
2013/11/24 Javascript
Javascript浅谈之this
2013/12/17 Javascript
JavaScript学习笔记之内置对象
2015/01/22 Javascript
js实现Select下拉框具有输入功能的方法
2015/02/06 Javascript
js+html5实现canvas绘制镂空字体文本的方法
2015/06/05 Javascript
javascript+HTML5的Canvas实现Lab单车动画效果
2015/08/07 Javascript
jQuery选择器及jquery案例详解(必看)
2016/05/20 Javascript
JS加载器如何动态加载外部js文件
2016/05/26 Javascript
JS中Safari浏览器中的Date
2017/07/17 Javascript
VSCode 配置React Native开发环境的方法
2017/12/27 Javascript
浅谈vue中改elementUI默认样式引发的static与assets的区别
2018/02/03 Javascript
详解webpack 打包文件体积过大解决方案(code splitting)
2018/04/10 Javascript
详解webpack的proxyTable无效的解决方案
2018/06/15 Javascript
详解vue-router数据加载与缓存使用总结
2018/10/29 Javascript
Python爬虫实例扒取2345天气预报
2018/03/04 Python
Python 爬取携程所有机票的实例代码
2018/06/11 Python
python 利用文件锁单例执行脚本的方法
2019/02/19 Python
python求最大值最小值方法总结
2019/06/25 Python
解决Python命令行下退格,删除,方向键乱码(亲测有效)
2020/01/16 Python
对tensorflow 中tile函数的使用详解
2020/02/07 Python
python+openCV对视频进行截取的实现
2020/11/27 Python
Ray-Ban雷朋西班牙官网:全球领先的太阳眼镜品牌
2018/11/28 全球购物
Envie de Fraise意大利:法国网上推出的孕妇装品牌
2020/10/18 全球购物
数据库测试通常都包括哪些方面
2015/11/30 面试题
质检部经理岗位职责
2014/02/19 职场文书
华清池导游词
2015/02/02 职场文书
如何开发一个渐进式Web应用程序PWA
2021/05/10 Javascript
pytorch Dropout过拟合的操作
2021/05/27 Python
vue项目proxyTable配置和部署服务器
2022/04/14 Vue.js