Browse Source

feat(student): 添加课时消耗列表功能

- 新增课时消耗列表页面,展示学生上课记录- 实现下拉刷新和上拉加载更多功能
- 添加请假状态展示
- 优化列表项样式,动态显示上课时间和课时数
master
liutong 1 year ago
parent
commit
70904dc166
  1. 11
      api/member.js
  2. 190
      pages/student/my/lesson_consumption.vue

11
api/member.js

@ -108,6 +108,17 @@ export default {
}) })
}, },
//获取课时列表
studentsSignList(data) {
let url = '/member/students_sign_list'
return http.post(url, data).then(res => {
return res;
})
},

190
pages/student/my/lesson_consumption.vue

@ -1,95 +1,29 @@
<!--课时消耗列表-->
<template> <template>
<view class="assemble"> <view class="assemble">
<view style="height: 50rpx;"></view> <view style="height: 50rpx;"></view>
<view class="ul"> <view class="ul">
<view class="li"> <view class="li" v-for="(v,k) in tableList" :key="k">
<view class="left"> <view class="left">
<view class="title">篮球少儿课</view> <view class="title">{{v.name}}</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view> <view class="date">上课时间{{v.create_time}}</view>
</view> </view>
<view class="right"> <view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view> <view
</view> v-if="v.status == 1"
</view> class="btn"
<view class="li"> style="background-color: #29d3b4;"
<view class="left"> >
<view class="title">篮球少儿课</view> {{v.hour}}课时
<view class="date">上课时间2020.05.30 15:30 - 17:30</view> </view>
</view>
<view class="right"> <view
<view class="btn" style="background-color: #29d3b4;">1课时</view> v-if="v.status == 2"
</view> class="btn"
</view> style="background-color: #FAD04D;"
<view class="li"> >
<view class="left"> 请假
<view class="title">篮球少儿课</view> </view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view>
</view>
<view class="li">
<view class="left">
<view class="title">篮球少儿课</view>
<view class="date">上课时间2020.05.30 15:30 - 17:30</view>
</view>
<view class="right">
<view class="btn" style="background-color: #29d3b4;">1课时</view>
</view> </view>
</view> </view>
</view> </view>
@ -97,15 +31,99 @@
</template> </template>
<script> <script>
import memberApi from '@/api/member.js';
export default { export default {
data() { data() {
return { return {
loading:false,//
lowerThreshold: 100,//
isReachedBottom: false,//|true=|false=
//
filteredData:{
page:1,//
limit:10,//
total:10,//
},
tableList:[],//
} }
}, },
onLoad(options) {
},
onShow(){
this.init()//
},
//
async onPullDownRefresh() {
//
await this.resetFilteredData()
await this.getList()
},
methods: { methods: {
//
async init(){
await this.getList()//
},
//()
loadMoreData() {
//
if (!this.isReachedBottom) {
this.isReachedBottom = true;//
this.getList();
}
},
//
async resetFilteredData() {
this.isReachedBottom = false; // 便
this.filteredData.page = 1//
this.filteredData.limit = 10//
this.filteredData.total = 10//
},
//
async getList(){
this.loading = true
let data = {...this.filteredData}
//
if(this.filteredData.page * this.filteredData.limit > this.filteredData.total){
this.loading = false
uni.showToast({
title: '暂无更多',
icon: 'none'
})
return
}
if(data.page == 1){
this.tableList = []
}
let res = await memberApi.studentsSignList(data)
this.loading = false
this.isReachedBottom = false;
if (res.code != 1){
uni.showToast({
title: res.msg,
icon: 'none'
})
return
}
this.tableList = this.tableList.concat(res.data.data); // 使 concat
console.log('列表',this.tableList)
this.filteredData.total = res.data.total
this.filteredData.page++
},
} }
} }
</script> </script>

Loading…
Cancel
Save