微信小程序信息展示列表
wxml
<!-- 輪播圖 -->
<view class='haibao' bindtap="seeDetail" id="{{item.activityContentId}}" >
<swiper indicator-dots='{{indicatorDots}}' autoplay='{{autoplay}}' interval='{{interval}}' duration='{{duration}}' circular='true' indicator-dots='true' circular='{{circular}}' >
<block wx:for="{{carousels}}">
<swiper-item>
<image src='{{baseUrl}}{{item.imgUrl}}' class='slide-image' binderror="errorFunction"></image>
<text class="item-title">{{item.title}}</text>
</swiper-item>
</block>
</swiper>
</view>
<!-- 圖標 -->
<!-- <view class="nav">
<view bindtap='classify'>
<view>
<image src="/images/icon/renwu.jpg" style="width:80rpx;height:80rpx;"></image>
</view>
<view>藝人菜譜</view>
</view>
<view bindtap='movies'>
<view>
<image src="/images/icon/zhibo.jpg" style="width:80rpx;height:80rpx;"></image>
</view>
<view>電影推薦</view>
</view>
<view bindtap='post'>
<view>
<image src="/images/icon/chengshi.jpg" style="width:80rpx;height:80rpx;"></image>
</view>
<view>閱讀文章</view>
</view>
</view> -->
<!-- 數據列表 -->
<view wx:for="{{dataList}}" class="item" bindtap="seeDetail" id="{{item.activityContentId}}">
<!-- 線條 -->
<view class="line"></view>
<view class="title">{{item.activityTitle}}</view>
<view class='pic'>
<image src="{{baseUrl}}{{item.activitySmimg}}" style="width:100%;height:203px;"></image>
</view>
<view class="info">
<view class="desc">
<text>{{item.activityType}}</text>
<text>{{item.activityLocation}}</text>
<!-- <text>{{item.createDate}}</text> -->
<text>{{util.sub(item.activityTime)}}</text>
</view>
</view>
</view>
<!-- 加載標志 -->
<view class="load_more" hidden="{{!loading}}">
<view class="load_loading"></view>
<view class="load-tips">正在加載……</view>
</view>
<wxs module="util">
var sub = function(val) {
return val.substring(0, 10)
}
module.exports.sub = sub;
</wxs>
wxss
/**index.wxss**/
.item-title {
margin-bottom: 16rpx;
font-size: 24rpx;
}
/* 圖標 */
.nav{
display: flex;
flex-direction: row;
padding:10px;
}
.nav view{
margin:0 auto;
text-align: center;
font-size: 13px;
}
/* 輪播圖 */
.haibao swiper {
height: 150px;
}
/* 圖片 */
.slide-image {
width: 100%;
height: 150px;
}
/* 卡片 */
.item {
margin-top: 15px;
margin-bottom: 10px;
}
/* 標題 */
.title {
margin-top: 8px;
margin-left: 10px;
margin-bottom: 8px;
color: #444;
font-weight: bold;
font-size: 18px;
}
/* 信息 */
.info {
display: flex;
flex-direction: row;
font-size: 12px;
color: #999;
}
/* 前半部分 */
.desc {
width: 95%;
margin-left: 10px;
}
/* 每條信息 */
.desc text {
margin-right: 10px;
}
/* 后半部分 */
.opr {
width: 6%;
}
/* 打叉 */
.opr view {
width: 15px;
height: 13px;
border: 1px solid #ccc;
line-height: 10px;
text-align: center;
border-radius: 5px;
}
/* 框架 */
.load_more {
margin: 20rpx auto;
font-size: 14px;
text-align: center;
display: flex;
flex-direction: row;
justify-content: center;
}
/* 標志 */
.load_loading {
margin: 0 5px;
width: 40rpx;
height: 40rpx;
/* display: inline-block;
vertical-align: middle; */
animation: weuiLoading 5s steps(12, end) infinite;
background: transparent url() no-repeat;
background-size: 100%;
}
/* 文字 */
.load_tips {
display: inline-block;
vertical-align: middle;
}
.linecenter {
text-align: center;
display: flex;
width: 95%;
flex-direction: row;
justify-content: center;
}
.line {
border: 1px solid #ccc;
opacity: 0.3;
}
js
//index.js
//獲取應用實例
const app = getApp()
// 頁數
var pageNum = 1;
// 頁量
var pageCount = 10;
Page({
// 設置數據
data: {
// 列表數據數組
dataList: [],
// 輪播圖
indicatorDots: true,
autoplay: true,
interval: 3000,
duration: 500,
circular: true,
// 基地址
baseUrl: app.globalData.baseUrl,
// 下拉刷新,上拉加載
loading: false,
// loaded: false,
carousels: [],
// itemtitle: [],
avatar: '',
// 圖片
imgUrls: [
"/images/haibao/haibao-1.jpg",
"/images/haibao/haibao-2.jpg"
]
},
// 跳轉
classify: function () {
wx.navigateTo({
url: '../classify/classify',
})
},
post: function () {
wx.navigateTo({
url: '../posts/post',
})
},
movies: function () {
wx.navigateTo({
url: '../movies/movies',
})
},
errorFunction: function () {
this.setData({
avatar: 'images/haibao/haibao-1.jpg'
})
},
/**
* 生命周期函數--監聽頁面加載
* 進入頁面的時候開始加載一次數據
*/
onLoad: function(options) {
// 轉換
var that = this;
// 加載輪播
that.loadPic();
// 加載數據列表 參數:頁數於頁量
that.loadList(pageNum, pageCount);
// 顯示加載中
wx.showLoading({
title: '加載中',
mask: true
})
// 顯示時間
setTimeout(function() {
wx.hideLoading()
}, 2000)
},
// 加載輪播
loadPic: function(){
var that = this;
wx.request({
url: app.globalData.baseUrl + 'js//carousel/list/', // 接口地址
method: 'GET',
header: {
'content-type': 'application/json' //默認值
},
// 成功
success: function (res) {
console.log("interface/activity/carousel/list/ 輪播 成功", res.data.data);
console.log(res.data.data[0].imgUrl)
// console.log(res.data.data.title)
that.setData({
carousels: res.data.data,
// itemtitle: res.data.data.titile
});
},
// 失敗
fail: function (err) {
console.log("interface/activity/carousel/list/ 輪播 失敗", err);
}
})
},
// 加載數據的函數
loadList: function(page, count) {
var that = this;
//發送請求
wx.request({
url: app.globalData.baseUrl + 'j/activ' + page + '/' + count, //接口地址
method: 'GET',
header: {
'content-type': 'application/json' //默認值
},
// 成功
success: function(res) {
console.log("dataList:", that.data.dataList);
var arr = that.data.dataList;
if (page == 1) {
arr = [];
}
if (res.data.total == 0) {
//沒有數據返回
console.log(res.data.msg);
// 顯示沒有更多數據了
wx.showToast({
title: '沒有更多數據了……',
icon: 'none'
})
// 顯示時間
setTimeout(function() {
wx.hideToast()
}, 2000)
pageNum -= 1;
return;
}
arr = arr.concat(res.data.data);
console.log("interface/activity/list 成功", res.data);
that.setData({
dataList: arr
});
},
// 失敗
fail: function(err) {
console.log("interface/activity/list 失敗", err);
}
})
},
// 詳情頁函數
seeDetail: function(e) {
if (!e.currentTarget.id == "") {
wx.navigateTo({
url: '../detail/detail?contentId=' + e.currentTarget.id
})
console.log(e)
} else {
console.log("無內容")
}
},
/**
* 頁面相關事件處理函數--監聽用戶下拉動作,刷新
*/
onPullDownRefresh: function() {
console.log("下拉刷新")
var that = this;
wx.showNavigationBarLoading()
setTimeout(() => {
// 輪播刷新
that.loadPic();
pageNum = 1;
that.loadList(pageNum, pageCount);
wx.hideNavigationBarLoading() //完成停止加載
wx.stopPullDownRefresh() //停止下拉刷新
}, 2000)
},
/**
* 頁面上拉觸底事件的處理函數
*/
onReachBottom: function() {
var that = this;
console.log('上拉')
if (this.data.loading) return;
this.setData({
loading: true
});
setTimeout(() => {
pageNum += 1;
that.loadList(pageNum, pageCount);
that.setData({
loading: false
})
}, 2000)
},
/**
* 用戶點擊右上角分享
*/
onShareAppMessage: function() {
},
// 獲取用戶
getUserInfo: function(e) {
console.log(e)
app.globalData.userInfo = e.detail.userInfo
this.setData({
userInfo: e.detail.userInfo,
hasUserInfo: true
})
}
})
json
{
"enablePullDownRefresh": true
}
達叔小生:往后余生,唯獨有你
You and me, we are family !
90后帥氣小伙,良好的開發習慣;獨立思考的能力;主動並且善於溝通
簡書博客: 達叔小生
https://www.jianshu.com/u/c785ece603d1
結語
- 下面我將繼續對 其他知識 深入講解 ,有興趣可以繼續關注
- 小禮物走一走 or 點贊