| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253 | <template>	<view class="phone-list-page">		<view class="phone-navBar-box">			<view @click="goUpPage" class="nav-bar-icon"></view>			<text class="nav-bar-title">成绩</text>			<view class="nav-bar-icon-box">				<uni-icons class="nav-bar-right-icon" type="search" size="22" color="#666"					@click="toggle('top')"></uni-icons>			</view>		</view>		<!-- 查询职业 -->		<!-- <view class="phone-search-box">			<input class="search-input" placeholder="请输入职业名称" v-model="data.zyName" />			<view class="search-icon" @click="handleSearch">				<uni-icons type="search" size="24" color="#fff"></uni-icons>			</view>		</view> -->				<view>			<search-dialog ref="searchDialogRef" 				@search-btn="dialogSearchBtn"				@reset-search="dialogSearchReset"></search-dialog>		</view>				<!-- 课程列表 -->		<scroll-view scroll-y="true" refresher-enabled="true" :refresher-triggered="data.loading"				:refresher-threshold="50" refresher-background="transparent" @refresherrefresh="onRefresh"				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="item-card-row">								<!-- 数量 -->								<view class="ks-item-top">									<view class="ks-name">{{item.ksName}}</view>									<view class="ks-zyLevelName">{{item.zyLevelName}}</view>								</view>																<view class="ks-totalTm-row">									<view class="ks-totalTm">										<icon class="phone-user-icon" />姓名:{{item.realName}} 									</view>									<view class="ks-totalTm">										<icon class="phone-tel-icon" />手机号:{{item.userName}} 									</view>								</view>								<view class="ks-totalTm">									<icon class="phone-time-icon" />{{item.answerStartTime}} - {{item.answerEndTime}}								</view>								<!-- <view class="ks-totalTm">									<icon class="phone-time-icon" /> {{item.userScore}} / {{item.okScore}}/{{item.ksScore}}								</view> -->								<!-- 分数 -->								<view class="ks-score-content">									<view class="ks-score">										<icon class="phone-zongfen-icon" />总分:<text>{{item.ksScore}}</text>									</view>									<view class="ks-okScore cj-okScore">										<icon class="phone-jigefen-icon" />及格分:<text>{{item.okScore}}</text>									</view>									<view class="ks-getScore">										<icon class="phone-defen-icon" />得分:<text>{{item.userScore}}</text>									</view>								</view>								<button @click="checkKecheng(item)" type="primary" size="mini"									class="item-view-btn">查看内容</button>							</view>						</template>					</uni-list-item>					<uni-load-more :status="data.state" @click="getMore(0)"						:contentText="data.contentText"></uni-load-more>				</uni-list>			</scroll-view>		<!-- 页面底端 -->		<customTabbarAdminVue :current-tab="0"></customTabbarAdminVue>	</view></template><script setup>	import customTabbarAdminVue from "@/components/custom-tabbar/custom-tabbar-admin.vue";	import {		ref,		reactive	} from "vue";	import {		onLoad	} from "@dcloudio/uni-app";	import * as kaoshiApi from "@/api/kaoshi.js"	import {		formatDuration	} from "@/utils/common.js"	import searchDialog from "@/pages/admin/jiazheng/common/search.vue";		const data = reactive({		zyName: '', // 职业名称		list: [], // 考试列表		loading: false,		page: 0,		size: 10,		state: 'more',		contentText: {			contentdown: '查看更多',			contentrefresh: '加载中',			contentnomore: '没有更多'		},		userName: '',		realName: '',	})		const searchDialogRef = ref(null);		function dialogSearchReset() {		data.userName = '';		data.realName = '';	}		function dialogSearchBtn(name, searchData) {		switch (name) {			case '姓名':				dialogSearchReset();				data.realName = searchData.value;				break;			case '手机号':				data.userName = searchData.value;				break;		}		onRefresh();	}		const toggle = (data, index) => {		searchDialogRef.value.handleShow();	}	function goUpPage() {		uni.redirectTo({			url: '/pages/admin/ShouYe/shouye'		})	}	function handleSearch() {		data.page = 0;		refreshData();	}	function checkKecheng(item) {		uni.navigateTo({			url: `/pages/admin/Chengji/ksScoreShijuan?hisId=${item.hisId}`		})	}	function onRefresh() {		data.page = 0;		data.list = [];		data.loading = true;		refreshData();	}	function refreshData() {		const opt = {			page: 1,			size: 10, // 固定查询10条			userName: data.userName,			realName: data.realName		}		data.list = [];		// 数学		data.state = 'loading';		data.page++;		opt.page = data.page;		kaoshiApi.getAdminKsChengjiList(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条			userName: data.userName,			realName: data.realName		}		if (data.state == 'no-more') return;		data.state = 'loading';		data.page++;		opt.page = data.page;		kaoshiApi.getAdminKsChengjiList(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(() => {		getMore()	})</script><style lang="scss" scoped>	.phone-kecheng-page {		background-color: #ccc;		box-sizing: border-box;	}	.phone-search-content {		position: relative;		background-color: #fff;		height: 42px;		.search-input {			height: 42px;			line-height: 40px;			border-radius: 20px;			border: 1px solid #ccc;			padding: 0 70px 0 20px;		}		.search-icon {			position: absolute;			right: 5px;			top: 4px;			padding: 6px;			background-color: #ccc;			border-radius: 20px;			width: 50px;			text-align: center;		}	}</style>
 |