微信小程序页面滑动屏幕加载数据效果

发布时间 - 2026-01-11 02:57:51    点击率:

滑动屏幕加载数据是任何小程序中都会用到的功能,本文我就将这个功能整理给大家,希望对大家有意。我们先看看效果图:

创建目录

首先我们现在项目中创建资讯目录,以下是我自己创建的目录,大家可以根据自己的需求创建。如图所示:

创建lists.js文件

以下是lists.js代码

var app = getApp()
Page({
 data: {
 newsList: [],
 lastid: 0,
 toastHidden: true,
 confirmHidden: true,
 isfrist: 1,
 loadHidden: true,
 moreHidden: 'none',
 msg: '没有更多文章了'
 },
 loadData: function (lastid) {
 //显示出加载中的提示
 this.setData({ loadHidden: false })
 var limit = 10
 var that = this
 wx.request({
  url: 'http://127.0.0.1:9090/hpm_bill_web/news/getnewslist', //数据接口
  data: { lastid: lastid, limit: limit },
  header: {
  'Content-Type': 'application/json'
  },
  success: function (res) {
  if (!res.data) {
   that.setData({ toastHidden: false })
   that.setData({ moreHidden: 'none' })
   return false
  }
  var len = res.data.length
  var oldLastid = lastid
  if(len != 0) {
   that.setData({ lastid: res.data[len - 1].id })
  } else {
   that.setData({ toastHidden: false})
  }
  var dataArr = that.data.newsList
  var newData = dataArr.concat(res.data);
   if (oldLastid == 0) {
   wx.setStorageSync('CmsList', newData)
   }
  that.setData({ newsList: newData })
  that.setData({ moreHidden: '' })
  },
  fail: function (res) {
  if (lastid == 0) {
   var newData = wx.getStorageSync('CmsList')
   if(newData) {
   that.setData({ newsList: newData })
   that.setData({ moreHidden: '' })
   var len = newData.length
   if (len != 0) {
    that.setData({ lastid: newData[len - 1].id })
   } else {
    that.setData({ toastHidden: false })
   }
   console.log('data from cache');
   }
   } else {
   that.setData({ toastHidden: false, moreHidden: 'none', msg: '当前网格异常,请稍后再试' })
   }
  },
  complete: function () {
  //显示出加载中的提示
  that.setData({ loadHidden: true })
  }
 })
 },
 loadMore: function (event) {
 var id = event.currentTarget.dataset.lastid
 var isfrist = event.currentTarget.dataset.isfrist
 var that = this
 wx.getNetworkType({
  success: function (res) {
  var networkType = res.networkType // 返回网络类型2g,3g,4g,wifi
  if (networkType != 'wifi' && isfrist == '1') {
   that.setData({ confirmHidden: false })
  }
  }
 })
 this.setData({ isfrist: 0 })
 this.loadData(id);
 },
 onLoad: function () {
 var that = this
 this.loadData(0);
 },
 toastChange: function () {
 this.setData({ toastHidden: true })
 },
 modalChange: function () {
 this.setData({ confirmHidden: true })
 }
})

创建页面文件(lists.wxml)

<view class="warp">
 <!-- 文章列表模板 begin -->
 <template name="items">
 <navigator url="../../pages/detail/detail?id={{id}}" hover-class="navigator-hover">
  <view class="imgs">
  <image src="{{image}}" class="in-img" background-size="cover" model="scaleToFill"></image>
  </view>
  <view class="infos">
  <view class="title">{{name}}</view>
  <view class="dates">{{createtime}}</view>
  </view>
 </navigator>
 </template>
 <!-- 文章列表模板 end -->
 <!-- 循环输出列表 begin -->
 <view wx:for="{{newsList}}" class="list">
 <template is="items" data="{{...item}}" />
 </view>
 <!-- 循环输出列表 end -->
<loading hidden="{{loadHidden}}" bindchange="loadChange">
 数据加载中...
</loading>
 <view bindtap="loadMore" data-lastid="{{lastid}}" data-isfrist="{{isfrist}}" class="loadMore" style="display:{{moreHidden}}">加载更多</view>
 <toast hidden="{{toastHidden}}" bindchange="toastChange" duration="3000">{{msg}}</toast>
 <modal title="温馨提示" no-cancel confirm-text="明确" cancel-text="关闭" hidden="{{confirmHidden}}" bindconfirm="modalChange" bindcancel="modalChange">你当前不在在WIFI网格下下,会产生流量费用</modal>
</view>

创建页面样式(lists.wxss)

.warp {height:100%;display:flex;flex-direction: column;padding:20rpx;}
navigator {overflow: hidden;}
.list {margin-bottom:20rpx;height:200rpx;position:relative;}
.imgs{float:left;}
.imgs image {display:block;width:200rpx;height:200rpx;}
.infos {float:left;width:480rpx;height:200rpx;padding:20rpx 0 0 20rpx}
.title {font-size:20px; font-family: Microsoft Yahei}
.dates {font-size:16px;color: #aaa; position: absolute;bottom:0;}
.loadMore {text-align: center; margin:30px;color:#aaa;font-size:16px;}


通过以上代码就能实现在屏幕上滑动显示数据的功能。

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


# 小程序页面滑动屏幕加载  # 小程序滑动屏幕加载数据  # 小程序滑动加载数据  # 微信小程序实现卡片左右滑动效果的示例代码  # 微信小程序左右滑动的实现代码  # 微信小程序滚动Tab实现左右可滑动切换  # 微信小程序图片横向左右滑动案例  # 微信小程序左右滑动切换页面详解及实例代码  # 微信小程序侧边栏滑动特效(左右滑动)  # 小程序实现点击tab切换左右滑动  # 小程序实现日历左右滑动效果  # 微信小程序之滑动页面隐藏和显示组件功能的实现代码  # 微信小程序实现页面左右滑动  # 文章列表  # 自己的  # 加载  # 加载中  # 就能  # 给大家  # 我们现在  # 就将  # 可以根据  # 温馨提示  # 大家多多  # 再试  # 数据加载中  # 请稍后  # 如图所示  # 屏幕上  # Type  # Content  # return  # header 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Swift中switch语句区间和元组模式匹配  如何在IIS服务器上快速部署高效网站?  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  Bootstrap整体框架之JavaScript插件架构  浅述节点的创建及常见功能的实现  PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)  清除minerd进程的简单方法  Laravel如何优化应用性能?(缓存和优化命令)  千库网官网入口推荐 千库网设计创意平台入口  Laravel模型事件有哪些_Laravel Model Event生命周期详解  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  做企业网站制作流程,企业网站制作基本流程有哪些?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  如何为不同团队 ID 动态生成多个独立按钮  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何解决hover在ie6中的兼容性问题  中山网站推广排名,中山信息港登录入口?  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  EditPlus中的正则表达式 实战(1)  如何在新浪SAE免费搭建个人博客?  如何在建站之星网店版论坛获取技术支持?  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Laravel如何生成URL和重定向?(路由助手函数)  Laravel如何使用Eloquent进行子查询  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  怎样使用JSON进行数据交换_它有什么限制  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何快速搭建安全的FTP站点?  Java遍历集合的三种方式  Android Socket接口实现即时通讯实例代码  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  网站制作报价单模板图片,小松挖机官方网站报价?  北京专业网站制作设计师招聘,北京白云观官方网站?  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  魔毅自助建站系统:模板定制与SEO优化一键生成指南  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?