php微信小程序向下滑动,微信小程序页面滑动屏幕加载数据的实例详解

这篇文章主要为大家详细介绍了微信小程序页面滑动屏幕加载数据效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

53f1c32b43abd43ff9349458c22b6930.png

创建目录

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

baadef843300d2a4858443457c08829c.png

创建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)

{{name}}

{{createtime}}

数据加载中...

加载更多

{{msg}}

你当前不在在WIFI网格下下,会产生流量费用

创建页面样式(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;}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值