| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 | <template>	<view class="phone-list-page kecheng-list">		<view class="icon-title-bjcolor-navBar-box">			<view @click="goUpPage" class="nav-bar-icon"></view>			<text class="nav-bar-title">课程管理</text>		</view>		<!-- 课程列表 -->		<scroll-view scroll-y="true" refresher-enabled="true" :refresher-triggered="data.loading"			:refresher-threshold="50" refresher-background="transparent" @refresherrefresh="onRefresh" @scrolltolower="onScrolltolower"			class="phone-scroll-view">			<uni-list class="admin-list-box">				<uni-list-item v-for="item in data.list" class="admin-list-item-box">					<template v-slot:body>						<view class="kecheng-list-card-box" @click="checkKecheng(item)">							<img :src="item.pic">							<view class="card-right-box">								<view class="card-name">{{item.name}}</view>								<view class="ks-totalTm kc-fenlei">									<icon class="phone-fenlei-icon" />分类:{{item.kcClassifyName}}								</view>								<view>课时:{{formatSecondsToCnhms(item.period, true)}}</view>								<view>{{item.createTime}}</view>							</view>						</view>					</template>				</uni-list-item>				<uni-load-more :status="data.state" @click="getMore(0)" :contentText="data.contentText"></uni-load-more>			</uni-list>		</scroll-view>		<!-- 页面底端 -->		<customTabbarClientVue></customTabbarClientVue>	</view></template><script setup>	import customTabbarClientVue from "@/components/custom-tabbar/custom-tabbar-client.vue";	import {		ref,		reactive	} from "vue";	import {		onLoad,		onShow	} from "@dcloudio/uni-app";	import * as kechengApi from "@/api/kecheng.js"	import {		formatSecondsToCnhms	} from "@/utils/common.js"	const data = reactive({		list: [], // 考试列表		loading: false,		page: 0,		size: 10,		state: 'more',		contentText: {			contentdown: '查看更多',			contentrefresh: '加载中',			contentnomore: '没有更多'		},		from: ''	})		function onScrolltolower() {		getMore()	}	function goUpPage() {		const pages = getCurrentPages();		if (pages.length > 1) {			uni.navigateBack()		} else {			/* uni.redirectTo({				url: '/pages/client/ShouYe/shouye'			})	 */			history.back();		}	}	function handleSearch() {		data.page = 0;		refreshData();	}	function checkKecheng(item) {		uni.navigateTo({			url: `/pages/client/Kecheng/study?kcId=${item.kcId}&jzId=${item.jzId}&from=kechengList`		})	}	function onRefresh() {		data.page = 0;		data.list = [];		data.loading = true;		refreshData();	}	function refreshData() {		const opt = {			page: 1,			size: 10, // 固定查询10条		}		data.list = [];		// 数学		data.state = 'loading';		data.page++;		opt.page = data.page;		kechengApi.getClientKechengList(opt).then(res => {			data.list = data.list.concat(res.data.data);			data.loading = false;			if (res.data.total > data.list.length) {				data.state = 'more';				data.loading = false;			} else {				data.state = 'no-more';				data.loading = false;			}		}).catch(err => {			data.state = 'more';			data.loading = false;		})	}	function getMore() {		const opt = {			page: 1,			size: 10, // 固定查询10条		}		if (data.state == 'no-more') return;		data.state = 'loading';		data.page++;		opt.page = data.page;		kechengApi.getClientKechengList(opt).then(res => {			data.list = data.list.concat(res.data.data);			data.loading = false;			if (res.data.total > data.list.length) {				data.state = 'more';				data.loading = false;			} else {				data.state = 'no-more';				data.loading = false;			}		}).catch(err => {			data.state = 'more';			data.loading = false;		})	}	onLoad((options) => {		data.from = options.from;	})	onShow(() => {		getMore()	})</script>
 |