微信小程序实现下拉刷新和轮播图效果
网络编程 2021-07-04 17:33www.168986.cn编程入门
这篇文章主要为大家详细介绍了微信小程序实现下拉刷新和轮播图效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了微信小程序实现下拉刷新和轮播图展示的具体代码,供大家参考,具体内容如下
先上图,再解释
wxml页面代码:
<scroll-view scroll-y="true" bindscrolltolower="lower" style="height:{{screenH}}px" class="scroll"> <swiper aulay="{{aulay}}" interval="{{interval}}" duration="{{duration}}" class="swiper-box"> <block wx:for="{{imgUrls}}"> <swiper-item> <image src="{{item}}" class="slide-img" style="height:100%"></image> </swiper-item> </block> </swiper> <view class="text-food">美食篇</view> <view class="list-box clear" wx:for="{{list}}"> <image src="{{item.pic}}" class="img-food fl"></image> <view class="fl detail-view"> <text class="text-name">{{item.name}}</text> <view class="use-text">用餐人数<text>{{item.cookingtime}}</text></view> <view class="use-text overflow">菜谱说明<text>{{item.content}}</text></view> </view> </view> <view class="loading-view"> <image src="../../img/loading.gif" class="loading-img" wx:if="{{hasMore}}"></image> <text wx:else class="no-data">没有更多内容了</text> </view> </scroll-view>
wxss样式:
.fl { float: left; } .fr { float: right; } .clear:after { content: ''; display: block; clear: both; } view,scroll-view,swiper{ margin: 0px; padding: 0px; box-sizing: border-box; } .overflow{ overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .scroll{ wwidth: 100%; } .scroll .slide-img{ width: 100%; display: block; } .scroll .text-food{ color: #666; font-size: 30rpx; margin: 15rpx 0rpx 20rpx 1%; height: 30rpx; border-left: 2px solid rgb(0, 187, 161); padding-left: 10rpx; line-height: 30rpx; } .scroll .list-box{ padding: 0px 0px 20rpx 1%; margin: 20rpx 0px; border-bottom: 1px solid #d1d1d1; } .list-box .img-food{ width: 180rpx; height: 180rpx; } .list-box .detail-view{ width: calc(100% - 180rpx); padding-left: 4%; height: 180rpx; padding-: 20rpx; } .detail-view .text-name{ color: rgb(0, 187, 161); font-size: 32rpx; } .detail-view .use-text{ color: #666; font-size: 28rpx; margin: 15rpx 0px; } .loading-view{ text-align: center; margin-bottom: 40rpx; } .loading-view .loading-img{ width: 32px; height: 32px; } .loading-view .no-data{ color: #666; font-size: 28rpx; }
js代码:
//fresh.js var work_util = require('../../utils/work_util.js'); //获取应用实例 var app = getApp() Page({ data: { screenH:0, aulay:true, duration:500, interval:3000, hasMore:true, imgUrls:[ '../../img/test1.jpg', '../../img/test2.jpg', '../../img/test3.jpg', ], pageNum:10, list:[] }, //事件处理函数 bindViewTap: function() { wx.navigateTo({ url: '../logs/logs' }) }, onLoad: function () { console.log('onLoad'); var that = this; wx.getSystemInfo({ suess: function(res) { that.setData({ screenH:res.windowHeight 1.5 }); console.log(that.data.screenH+"====-------------"); } }); var url = 'https://api.jisuapi./recipe/search?keyword=鸡肉&num=this.data.pageNum&appkey=(ps:你的appkey)'; work_util._get(url,function(res){ that.setData({ list:res.data.result.list }); console.log("成功请求============================="); },function(){ }); //调用应用实例的方法获取全局数据 app.getUserInfo(function(userInfo){ //更新数据 that.setData({ userInfo:userInfo }) }) }, lower:function(){ console.log("滑到底部了==================="); var pageNum = this.data.pageNum + 5; var that = this; if(!that.data.hasMore || pageNum == 40){ that.setData({ hasMore:false }); return; } console.log(pageNum+"页数=========================="); var url = 'https://api.jisuapi./recipe/search?keyword=白菜&num='+(pageNum)+'&appkey=(ps:你的appkey)'; work_util._get(url,function(res){ that.setData({ list:that.data.list.concat(res.data.result.list), pageNum:pageNum }); console.log("成功请求2============================="); },function(){ }); console.log("---------------------------") }, })
work_util.js 代码如下:(主要是对wx.request的请求做了类似于封装调用方便用的。)
/ url 请求地址 suess 成功的回调 fail 失败的回调 / function _get( url, suess, fail ) { console.log( "------start---_get----" ); wx.request( { url: url, header: { 'Content-Type': 'application/json' }, suess: function( res ) { suess( res ); console.log("成功引用了=================="); }, fail: function( res ) { fail( res ); } }); console.log( "----end-----_get----" ); } / url 请求地址 suess 成功的回调 fail 失败的回调 / function _post(url,data, suess, fail ) { console.log( "----_post--start-------" ); wx.request( { url: url, header: { 'Content-Type': 'content-type x--form-urlencoded', 'Aept': 'application/json', }, method:'POST', data:'data='+data, suess: function( res ) { suess( res ); }, fail: function( res ) { fail( res ); } }); console.log( "----end-----_get----" ); } / url 请求地址 suess 成功的回调 fail 失败的回调 / function _post_json(url,data, suess, fail ) { console.log( "----_post--start-------" ); wx.request( { url: url, // header: { // 'Content-Type': 'application/json', // 'Aept': 'application/json', // }, method:'POST', data:data, suess: function( res ) { suess( res ); }, fail: function( res ) { fail( res ); } }); console.log( "----end----_post-----" ); } module.exports = { _get: _get, _post:_post, _post_json:_post_json }
由于我请求的api是来自己与极速数据的,所以是私人的appkey。不方便透露,大家可以去注册一下,里面可以免费申请使用的。换成自己的appkey就可以啦。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指