滑动屏幕加载数据是任何小程序中都会用到的功能,本文我就将这个功能整理给大家,希望对大家有意。我们先看看效果图:
创建目录
首先我们现在项目中创建资讯目录,以下是我自己创建的目录,大家可以根据自己的需求创建。如图所示:
创建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
相关文章:
代刷网站制作软件,别人代刷火车票靠谱吗?
宝塔面板如何快速创建新站点?
如何高效完成独享虚拟主机建站?
宝塔建站无法访问?如何排查配置与端口问题?
如何通过cPanel快速搭建网站?
,如何利用word制作宣传手册?
如何快速搭建支持数据库操作的智能建站平台?
如何快速搭建二级域名独立网站?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
如何在VPS电脑上快速搭建网站?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
简历在线制作网站免费版,如何创建个人简历?
建站之星如何优化SEO以实现高效排名?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
如何登录建站主机?访问步骤全解析
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
利用JavaScript实现拖拽改变元素大小
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何在腾讯云服务器快速搭建个人网站?
如何快速查询域名建站关键信息?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
长沙做网站要多少钱,长沙国安网络怎么样?
山东云建站价格为何差异显著?
如何配置FTP站点权限与安全设置?
如何在建站之星绑定自定义域名?
高端网站建设与定制开发一站式解决方案 中企动力
如何用y主机助手快速搭建网站?
如何快速打造个性化非模板自助建站?
想学网站制作怎么学,建立一个网站要花费多少?
如何用美橙互联一键搭建多站合一网站?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
TestNG的testng.xml配置文件怎么写
制作证书网站有哪些,全国城建培训中心证书查询官网?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何快速生成高效建站系统源代码?
学校为何禁止电信移动建设网站?
官网建站费用明细查询_企业建站套餐价格及收费标准指南
c# 服务器GC和工作站GC的区别和设置
如何在阿里云虚拟服务器快速搭建网站?
如何在万网自助建站中设置域名及备案?
建站之星伪静态规则如何正确配置?
如何在Windows虚拟主机上快速搭建网站?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
制作网站公司那家好,网络公司是做什么的?
如何在IIS中新建站点并配置端口与IP地址?
如何续费美橙建站之星域名及服务?
图册素材网站设计制作软件,图册的导出方式有几种?
建站之星微信建站一键生成小程序+多端营销系统
*请认真填写需求信息,我们会在24小时内与您取得联系。