Merge branch 'main' of http://124.243.245.42:3000/sdz/ks-app-employment-service
This commit is contained in:
@@ -57,7 +57,7 @@
|
|||||||
<div class="conten">截止时间:{{item.dueDate}}</div>
|
<div class="conten">截止时间:{{item.dueDate}}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flooter">
|
<div class="flooter">
|
||||||
<div v-if="item.gradeUser" @click="jumps('/packageB/train/mockExam/viewGrades')">查看成绩</div>
|
<div v-if="item.gradeUser" @click="jumps(item)">查看成绩</div>
|
||||||
<div @click="handleDetail(item)">详情</div>
|
<div @click="handleDetail(item)">详情</div>
|
||||||
<div @click="collects(item,1)" v-if="item.isCollect==0">
|
<div @click="collects(item,1)" v-if="item.isCollect==0">
|
||||||
<image :src="urls+'wsc.png'" mode="" style="width: 32rpx;height: 30rpx;"></image>
|
<image :src="urls+'wsc.png'" mode="" style="width: 32rpx;height: 30rpx;"></image>
|
||||||
@@ -263,14 +263,14 @@ function handleDetail(row){
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
function jumps(url){
|
function jumps(row){
|
||||||
navTo(url);
|
navTo('/packageB/train/mockExam/viewGrades?examPaperId='+row.examPaperId);
|
||||||
}
|
}
|
||||||
function clones(){
|
function clones(){
|
||||||
dialogVisible.value=false
|
dialogVisible.value=false
|
||||||
}
|
}
|
||||||
function handleOperation(row,i) {
|
function handleOperation(row,i) {
|
||||||
navTo(`/packageB/train/video/videoDetail?id=${video.videoId}`);
|
navTo(`/packageB/train/mockExam/startExam?examPaperId=${row.examPaperId}&timeLimit=${row.timeLimit}&name=${row.name}&types=${i}`);
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|||||||
482
packageB/train/mockExam/paperDetails.vue
Normal file
482
packageB/train/mockExam/paperDetails.vue
Normal file
@@ -0,0 +1,482 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-box">
|
||||||
|
<image src="../../../static/images/train/bj.jpg" class="bjImg" mode=""></image>
|
||||||
|
<div class="con-box">
|
||||||
|
<div class="header">
|
||||||
|
<div style="font-weight: 600;font-size: 32rpx;">{{rows.name}}</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="problemCard">
|
||||||
|
<div v-for="(item,index) in problemData" :key="index">
|
||||||
|
<template v-if="questionIndex==(index+1)">
|
||||||
|
<div class="problemTitle">
|
||||||
|
<span class="titleType" v-if="item.type=='single'">单选题</span>
|
||||||
|
<span class="titleType" v-if="item.type=='multiple'">多选题</span>
|
||||||
|
<span class="titleType" v-if="item.type=='judge'">判断题</span>
|
||||||
|
<span>{{item.content}}</span>
|
||||||
|
</div>
|
||||||
|
<div class="options" v-if="item.type=='single'">
|
||||||
|
<div class="opt" :class="item.choice!==''&&i==item.choice?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
||||||
|
<div class="optLab">{{indexToLetter(i)}}</div>
|
||||||
|
<span>{{val}}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="options" v-if="item.type=='multiple'">
|
||||||
|
<div class="opt" :class="judgment(i,index)?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
||||||
|
<div class="optLab">{{indexToLetter(i)}}</div>
|
||||||
|
<span>{{val}}</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="options" v-if="item.type=='judge'">
|
||||||
|
<div class="opt" :class="item.choice=='正确'?'active':''">
|
||||||
|
<span>正确</span>
|
||||||
|
</div>
|
||||||
|
<div class="opt" :class="item.choice=='错误'?'active':''">
|
||||||
|
<span>错误</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="analysis">
|
||||||
|
<div class="analysisHead correct" v-if="item.choosed==item.answer">
|
||||||
|
<div>回答正确!</div>
|
||||||
|
<div></div>
|
||||||
|
</div>
|
||||||
|
<div class="analysisHead errors" v-else>
|
||||||
|
<div>回答错误!</div>
|
||||||
|
<div></div>
|
||||||
|
</div>
|
||||||
|
<div class="analysisCon">
|
||||||
|
<div class="parse1">正确答案:</div>
|
||||||
|
<div class="parse2" v-if="item.type=='single'" style="color: #30A0FF;font-weight: bold;">{{String.fromCharCode(65 + Number(item.answer))}}.</div>
|
||||||
|
<div class="parse2" v-if="item.type=='multiple'" style="color: #30A0FF;font-weight: bold;">
|
||||||
|
<span v-for="(val,i) in parseOptions(item.answer)">{{indexToLetter(Number(val))}}.</span>
|
||||||
|
</div>
|
||||||
|
<div class="parse2" v-if="item.type=='judge'" style="color: #30A0FF;font-weight: bold;">{{item.answer}}</div>
|
||||||
|
</div>
|
||||||
|
<div class="analysisCon">
|
||||||
|
<div class="parse1">答案解析:</div>
|
||||||
|
<div class="parse2">{{item.answerDesc}}</div>
|
||||||
|
</div>
|
||||||
|
<div class="analysisCon">
|
||||||
|
<div class="parse1">知识点:</div>
|
||||||
|
<div>
|
||||||
|
<el-tag style="margin-right: 10px;">{{item.knowledgePoint}}</el-tag>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="footer">
|
||||||
|
<div class="footerLeft">
|
||||||
|
<div class="zuo" :class="questionIndex==1?'events':''" @click="questionIndex-=1"></div>
|
||||||
|
<div class="you" :class="questionIndex==problemData.length?'events':''" @click="questionIndex+=1"></div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div class="footerLeft">
|
||||||
|
<div @click="dialogVisible=true">
|
||||||
|
<div><span style="color: #1CADF5;">{{questionIndex}}</span>/{{problemData.length}}</div>
|
||||||
|
<div>题号</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="cards" v-if="dialogVisible">
|
||||||
|
<div class="cardCon">
|
||||||
|
<div class="cardHead">
|
||||||
|
<div>题号</div>
|
||||||
|
<div style="font-size: 40rpx;" @click="clones()">×</div>
|
||||||
|
</div>
|
||||||
|
<div class="questionNums">
|
||||||
|
<div class="questions" :class="item.whether=='正确'?'questionCorrect':item.whether=='错误'?'questionError':questionIndex==(index+1)?'questionsActive':''" @click="switchs(index)" v-for="(item,index) in problemList" :key="index">{{index+1}}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { reactive, inject, watch, ref, onMounted,onBeforeUnmount,computed } from 'vue';
|
||||||
|
import { onLoad, onShow } from '@dcloudio/uni-app';
|
||||||
|
const { $api,urls , navTo,navBack , vacanciesTo, formatTotal, config } = inject('globalFunction');
|
||||||
|
import useUserStore from '@/stores/useUserStore';
|
||||||
|
import useDictStore from '@/stores/useDictStore';
|
||||||
|
const userInfo = ref({});
|
||||||
|
const rows = ref({});
|
||||||
|
const Authorization = ref('');
|
||||||
|
const radio = ref('');
|
||||||
|
const radio2 = ref('');
|
||||||
|
const checkList = ref([]);
|
||||||
|
const questionIndex = ref(1);
|
||||||
|
const correctIndex = ref(0);
|
||||||
|
const errorsIndex = ref(0);
|
||||||
|
const elapsedTime = ref(0);
|
||||||
|
const judgWhether = ref('');
|
||||||
|
const isRunning = ref(false);
|
||||||
|
const dialogVisible = ref(false);
|
||||||
|
const problemData = ref([]);
|
||||||
|
const problemList = ref([]);
|
||||||
|
watch(questionIndex, (newVal, oldVal) => {
|
||||||
|
radio.value=""
|
||||||
|
radio2.value=""
|
||||||
|
checkList.value=[]
|
||||||
|
judgWhether.value=""
|
||||||
|
});
|
||||||
|
|
||||||
|
onLoad((options) => {
|
||||||
|
rows.value=options
|
||||||
|
Authorization.value=uni.getStorageSync('Padmin-Token')||''
|
||||||
|
getHeart();
|
||||||
|
});
|
||||||
|
onShow(()=>{
|
||||||
|
|
||||||
|
})
|
||||||
|
function getHeart() {
|
||||||
|
const raw =Authorization.value;
|
||||||
|
const token = typeof raw === "string" ? raw.trim() : "";
|
||||||
|
const headers = token ? { 'Authorization': raw.startsWith("Bearer ") ? raw : `Bearer ${token}` }: {}
|
||||||
|
$api.myRequest("/dashboard/auth/heart", {}, "POST", 10100, headers).then((resData) => {
|
||||||
|
if (resData.code == 200) {
|
||||||
|
getUserInfo();
|
||||||
|
} else {
|
||||||
|
navTo('/packageB/login')
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
function getUserInfo(){
|
||||||
|
let header={
|
||||||
|
'Authorization':Authorization.value
|
||||||
|
}
|
||||||
|
$api.myRequest('/system/user/login/user/info', {},'get',10100,header).then((resData) => {
|
||||||
|
userInfo.value = resData.info || {};
|
||||||
|
// userId.value=resData.info.userId
|
||||||
|
queryData()
|
||||||
|
});
|
||||||
|
};
|
||||||
|
function queryData(){
|
||||||
|
problemData.value=[]
|
||||||
|
let header={
|
||||||
|
'Authorization':Authorization.value,
|
||||||
|
'Content-Type':"application/x-www-form-urlencoded"
|
||||||
|
}
|
||||||
|
$api.myRequest('/train/public/trainExamDash/getExamByIdModel', {
|
||||||
|
userId: userInfo.value.userId,
|
||||||
|
examPaperId:rows.value.examPaperId,
|
||||||
|
examId:rows.value.examId,
|
||||||
|
},'post',9100,header).then((resData) => {
|
||||||
|
if(resData&&resData.code==200){
|
||||||
|
elapsedTime.value=(rows.value.timeLimit*60)
|
||||||
|
resData.data.forEach((item,i)=>{
|
||||||
|
if(item.type=='multiple'){
|
||||||
|
if(item.choosed){
|
||||||
|
item.choice=item.choosed.split(",");
|
||||||
|
item.submitAnswers=true
|
||||||
|
}else{
|
||||||
|
item.choice=[]
|
||||||
|
item.submitAnswers=false
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if(item.choosed){
|
||||||
|
item.choice=item.choosed;
|
||||||
|
item.submitAnswers=true
|
||||||
|
}else{
|
||||||
|
item.choice=""
|
||||||
|
item.submitAnswers=false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
problemData.value.push(item)
|
||||||
|
problemList.value.push({index:i+1,whether:""})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function judgment(i,indexs){
|
||||||
|
let arr=problemData.value[indexs].choice.join(",")
|
||||||
|
if(arr.indexOf(i) !== -1){
|
||||||
|
return true
|
||||||
|
}else{
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
};
|
||||||
|
// 解析选项
|
||||||
|
function parseOptions(options) {
|
||||||
|
if (!options) return [];
|
||||||
|
// 假设options是字符串格式,以分号分隔
|
||||||
|
if (typeof options === 'string') {
|
||||||
|
return options.split(',').filter(opt => opt.trim());
|
||||||
|
}
|
||||||
|
// 如果是数组,直接返回
|
||||||
|
if (Array.isArray(options)) {
|
||||||
|
return options;
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
};
|
||||||
|
function indexToLetter(index) {
|
||||||
|
// 将索引转换为对应的字母
|
||||||
|
return String.fromCharCode(65 + index);
|
||||||
|
};
|
||||||
|
function clones(){
|
||||||
|
dialogVisible.value=false
|
||||||
|
};
|
||||||
|
function switchs(i){
|
||||||
|
questionIndex.value=(i+1)
|
||||||
|
dialogVisible.value=false
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="stylus" scoped>
|
||||||
|
.app-box{
|
||||||
|
width: 100%;
|
||||||
|
height: 100vh;
|
||||||
|
position: relative;
|
||||||
|
.bjImg{
|
||||||
|
position: absolute;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.con-box{
|
||||||
|
position: absolute;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
left: 0;
|
||||||
|
top:0;
|
||||||
|
z-index: 10;
|
||||||
|
padding: 20rpx 28rpx;
|
||||||
|
box-sizing: border-box;
|
||||||
|
.header{
|
||||||
|
height: 100rpx;
|
||||||
|
padding: 0 10rpx;
|
||||||
|
background: linear-gradient(0deg, #4285EC 0%, #0BBAFB 100%);
|
||||||
|
color: #fff;
|
||||||
|
font-size: 26rpx;
|
||||||
|
border-radius: 10rpx
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.problemCard{
|
||||||
|
margin-top: 30rpx;
|
||||||
|
.problemTitle{
|
||||||
|
font-size: 30rpx;
|
||||||
|
.titleType{
|
||||||
|
display: inline-block;
|
||||||
|
background-color: #499FFF;
|
||||||
|
border-radius: 10rpx 10rpx 10rpx 0;
|
||||||
|
padding: 8rpx 12rpx;
|
||||||
|
color: #fff;
|
||||||
|
font-size: 26rpx;
|
||||||
|
margin-right: 20rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.options{
|
||||||
|
margin-top: 30rpx;
|
||||||
|
.opt{
|
||||||
|
height: 60rpx;
|
||||||
|
/* background-color: #F8F9FA; */
|
||||||
|
border-radius: 5px;
|
||||||
|
margin-bottom: 15px;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
padding-left: 30rpx;
|
||||||
|
box-sizing: border-box;
|
||||||
|
color: #808080;
|
||||||
|
font-size: 30rpx;
|
||||||
|
.optLab{
|
||||||
|
width: 40rpx;
|
||||||
|
height: 40rpx;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 40rpx;
|
||||||
|
border-radius: 50%;
|
||||||
|
background-color: #8C8C8C;
|
||||||
|
color: #fff;
|
||||||
|
font-weight: 600;
|
||||||
|
font-size: 32rpx;
|
||||||
|
margin-right: 20rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.active{
|
||||||
|
background: linear-gradient(90deg, #25A9F5 0%, #B1DBFF 100%);
|
||||||
|
color: #fff!important;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.active>view{
|
||||||
|
background-color: #fff!important;
|
||||||
|
color: #25A9F5!important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.analysis{
|
||||||
|
margin-top: 30rpx;
|
||||||
|
background-color: #fff;
|
||||||
|
border-radius: 6px;
|
||||||
|
margin-bottom: 15rpx;
|
||||||
|
border: 1px solid #10A8FF;
|
||||||
|
padding: 20rpx;
|
||||||
|
box-sizing: border-box;
|
||||||
|
.analysisHead{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
font-size: 32rpx;
|
||||||
|
font-family: Microsoft YaHei;
|
||||||
|
font-weight: bold;
|
||||||
|
letter-spacing: 2px;
|
||||||
|
}
|
||||||
|
.correct{
|
||||||
|
color: #67C23A;
|
||||||
|
}
|
||||||
|
.errors{
|
||||||
|
color: #F06A6A;
|
||||||
|
}
|
||||||
|
.analysisCon{
|
||||||
|
margin-top: 30rpx;
|
||||||
|
.parse1{
|
||||||
|
font-size: 30rpx;
|
||||||
|
font-family: Microsoft YaHei;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.parse2{
|
||||||
|
font-size: 26rpx;
|
||||||
|
color: #333;
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.problemBtns{
|
||||||
|
display: flex
|
||||||
|
align-items: center
|
||||||
|
justify-content: center
|
||||||
|
view{
|
||||||
|
width: 140rpx
|
||||||
|
height: 50rpx
|
||||||
|
text-align: center
|
||||||
|
line-height: 50rpx
|
||||||
|
background-color: #10A8FF
|
||||||
|
color: #fff
|
||||||
|
font-size: 28rpx
|
||||||
|
border-radius: 5rpx
|
||||||
|
margin-right: 10rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.footer{
|
||||||
|
width: 100%;
|
||||||
|
height: 120rpx;
|
||||||
|
border-top: 1px solid #ddd
|
||||||
|
position: fixed
|
||||||
|
bottom: 0
|
||||||
|
left: 0
|
||||||
|
display: flex
|
||||||
|
align-items: center
|
||||||
|
justify-content: space-between
|
||||||
|
.footerLeft{
|
||||||
|
display: flex
|
||||||
|
align-items: center
|
||||||
|
font-size: 30rpx;
|
||||||
|
text-align: center
|
||||||
|
.zuo{
|
||||||
|
width: 26rpx;
|
||||||
|
height: 26rpx;
|
||||||
|
border-top: 2px solid #666
|
||||||
|
border-left: 2px solid #666
|
||||||
|
transform: rotate(-45deg); /* 鼠标悬停时旋转360度 */
|
||||||
|
margin-left: 60rpx;
|
||||||
|
}
|
||||||
|
.you{
|
||||||
|
width: 26rpx;
|
||||||
|
height: 26rpx;
|
||||||
|
border-right: 2px solid #666
|
||||||
|
border-bottom: 2px solid #666
|
||||||
|
transform: rotate(-45deg); /* 鼠标悬停时旋转360度 */
|
||||||
|
// margin-left: 30rpx;
|
||||||
|
margin-right: 50rpx;
|
||||||
|
}
|
||||||
|
.icons{
|
||||||
|
width: 30rpx;
|
||||||
|
height: 30rpx;
|
||||||
|
color: #fff;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 30rpx;
|
||||||
|
border-radius: 50%
|
||||||
|
}
|
||||||
|
.texts{
|
||||||
|
font-size: 24rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.footerLeft>view{
|
||||||
|
margin-right: 40rpx;
|
||||||
|
}
|
||||||
|
.footerBtn{
|
||||||
|
width: 140rpx
|
||||||
|
height: 50rpx
|
||||||
|
text-align: center
|
||||||
|
line-height: 50rpx
|
||||||
|
background-color: #67C23A
|
||||||
|
color: #fff
|
||||||
|
font-size: 28rpx
|
||||||
|
border-radius: 5rpx
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.cards{
|
||||||
|
position: fixed;
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100vh;
|
||||||
|
background-color: rgba(0,0,0,0.5);
|
||||||
|
z-index: 1000;
|
||||||
|
padding: 100rpx 50rpx;
|
||||||
|
box-sizing: border-box;
|
||||||
|
.cardCon{
|
||||||
|
height: 100%;
|
||||||
|
background-color: #fff;
|
||||||
|
padding: 20rpx;
|
||||||
|
box-sizing: border-box;
|
||||||
|
.cardHead{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
|
font-size: 30rpx;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
.questionNums{
|
||||||
|
width: 100%;
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
}
|
||||||
|
.questions{
|
||||||
|
width: 60rpx;
|
||||||
|
height: 60rpx;
|
||||||
|
text-align: center;
|
||||||
|
line-height: 60rpx;
|
||||||
|
border-radius: 8rpx;
|
||||||
|
border: 2px solid #E0E0E0;
|
||||||
|
font-size: 28rpx;
|
||||||
|
margin-right: 15px;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.questionsActive{
|
||||||
|
background-color: #F0F9FF;
|
||||||
|
border: 2px solid #409EFF;
|
||||||
|
}
|
||||||
|
.questionCorrect{
|
||||||
|
background-color: #F0F9FF;
|
||||||
|
border: 2px solid #64BC38;
|
||||||
|
color: #6BC441;
|
||||||
|
}
|
||||||
|
.questionError{
|
||||||
|
background-color: #FFF1F0;
|
||||||
|
border: 2px solid #F56C6C;
|
||||||
|
color: #F36B6B;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.events{
|
||||||
|
pointer-events: none; /* 这会禁用所有指针事件 */
|
||||||
|
opacity: 0.5; /* 可选:改变透明度以视觉上表示不可点击 */
|
||||||
|
cursor: not-allowed; /* 可选:改变鼠标光标样式 */
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -3,10 +3,12 @@
|
|||||||
<image src="../../../static/images/train/bj.jpg" class="bjImg" mode=""></image>
|
<image src="../../../static/images/train/bj.jpg" class="bjImg" mode=""></image>
|
||||||
<div class="con-box">
|
<div class="con-box">
|
||||||
<div class="header">
|
<div class="header">
|
||||||
<div>正确率:{{accuracyRate}}%</div>
|
<div style="font-weight: 600;font-size: 32rpx;">{{rows.name}}</div>
|
||||||
<div>用时:{{formattedTime}}</div>
|
<div class="headerCon">
|
||||||
<div class="headBtn" v-if="isRunning" @click="pause">暂停</div>
|
<div>考试时长:{{rows.timeLimit}}分钟</div>
|
||||||
<div class="headBtn" v-if="!isRunning" @click="start">继续</div>
|
<div>{{formattedTime}}</div>
|
||||||
|
<div class="headBtn" @click="exit()">退出</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="problemCard">
|
<div class="problemCard">
|
||||||
<div v-for="(item,index) in problemData" :key="index">
|
<div v-for="(item,index) in problemData" :key="index">
|
||||||
@@ -18,57 +20,29 @@
|
|||||||
<span>{{item.content}}</span>
|
<span>{{item.content}}</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="options" v-if="item.type=='single'">
|
<div class="options" v-if="item.type=='single'">
|
||||||
<div class="opt" @click="selected(i)" :class="radio!==''&&i==radio?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
<div class="opt" @click="selected(i,index)" :class="item.choice!==''&&i==item.choice?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
||||||
<div class="optLab">{{indexToLetter(i)}}</div>
|
<div class="optLab">{{indexToLetter(i)}}</div>
|
||||||
<span>{{val}}</span>
|
<span>{{val}}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="options" v-if="item.type=='multiple'">
|
<div class="options" v-if="item.type=='multiple'">
|
||||||
<div class="opt" @click="selected2(i)" :class="judgment(i)?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
<div class="opt" @click="selected2(i,index)" :class="judgment(i,index)?'active':''" v-for="(val,i) in parseOptions(item.trainChooses)">
|
||||||
<div class="optLab">{{indexToLetter(i)}}</div>
|
<div class="optLab">{{indexToLetter(i)}}</div>
|
||||||
<span>{{val}}</span>
|
<span>{{val}}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="options" v-if="item.type=='judge'">
|
<div class="options" v-if="item.type=='judge'">
|
||||||
<div class="opt" @click="selected3('正确')" :class="radio2=='正确'?'active':''">
|
<div class="opt" @click="selected3('正确',index)" :class="item.choice=='正确'?'active':''">
|
||||||
<span>正确</span>
|
<span>正确</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="opt" @click="selected3('错误')" :class="radio2=='错误'?'active':''">
|
<div class="opt" @click="selected3('错误',index)" :class="item.choice=='错误'?'active':''">
|
||||||
<span>错误</span>
|
<span>错误</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="analysis" v-if="analysis">
|
|
||||||
<div class="analysisHead correct" v-if="judgWhether=='正确'">
|
|
||||||
<div>回答正确!</div>
|
|
||||||
<div></div>
|
|
||||||
</div>
|
|
||||||
<div class="analysisHead errors" v-if="judgWhether=='错误'">
|
|
||||||
<div>回答错误!</div>
|
|
||||||
<div></div>
|
|
||||||
</div>
|
|
||||||
<div class="analysisCon">
|
|
||||||
<div class="parse1">正确答案:</div>
|
|
||||||
<div class="parse2" v-if="item.type=='single'" style="color: #30A0FF;font-weight: bold;">{{String.fromCharCode(65 + Number(item.answer))}}.</div>
|
|
||||||
<div class="parse2" v-if="item.type=='multiple'" style="color: #30A0FF;font-weight: bold;">
|
|
||||||
<span v-for="(val,i) in parseOptions(item.answer)">{{indexToLetter(val-1)}}.</span>
|
|
||||||
</div>
|
|
||||||
<div class="parse2" v-if="item.type=='judge'" style="color: #30A0FF;font-weight: bold;">{{item.answer}}</div>
|
|
||||||
</div>
|
|
||||||
<div class="analysisCon">
|
|
||||||
<div class="parse1">答案解析:</div>
|
|
||||||
<div class="parse2">{{item.answerDesc}}</div>
|
|
||||||
</div>
|
|
||||||
<div class="analysisCon">
|
|
||||||
<div class="parse1">知识点:</div>
|
|
||||||
<div>
|
|
||||||
<el-tag style="margin-right: 10px;">{{item.knowledgePoint}}</el-tag>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="problemBtns">
|
<div class="problemBtns">
|
||||||
<div v-if="analysis&&judgWhether!=''&&questionIndex!=problemData.length" @click="questionIndex+=1">下一题</div>
|
<div :class="(problemData[questionIndex-1].type=='multiple'?problemData[questionIndex-1].choice.length==0:problemData[questionIndex-1].choice==='')?'events':''" @click="submit()">提交答案</div>
|
||||||
<div v-else :class="((radio===''&&radio2===''&&checkList.length==0&&isRunning)||analysis)?'events':''" @click="submit()">提交答案</div>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
@@ -77,25 +51,10 @@
|
|||||||
<div class="footerLeft">
|
<div class="footerLeft">
|
||||||
<div class="zuo" :class="questionIndex==1?'events':''" @click="questionIndex-=1"></div>
|
<div class="zuo" :class="questionIndex==1?'events':''" @click="questionIndex-=1"></div>
|
||||||
<div class="you" :class="questionIndex==problemData.length?'events':''" @click="questionIndex+=1"></div>
|
<div class="you" :class="questionIndex==problemData.length?'events':''" @click="questionIndex+=1"></div>
|
||||||
<div @click="collect(1)" style="text-align: center;font-size: 24rpx;" v-if="(problemData[questionIndex - 1]?.isCollect || 0)!=1">
|
|
||||||
<image :src="urls+'wsc.png'" mode="" style="width: 34rpx;height: 32rpx;"></image>
|
|
||||||
<div>收藏</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div @click="collect(0)" style="text-align: center;font-size: 24rpx;" v-if="(problemData[questionIndex - 1]?.isCollect || 0)==1">
|
<div class="footerBtn" @click="complete()">完成练习</div>
|
||||||
<image :src="urls+'video-sc.png'" mode="" style="width: 34rpx;height: 32rpx;"></image>
|
|
||||||
<div>取消</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="footerBtn" @click="exit()">完成练习</div>
|
|
||||||
<div class="footerLeft">
|
<div class="footerLeft">
|
||||||
<div>
|
|
||||||
<div class="icons" style="background-color: #1CADF5;">√</div>
|
|
||||||
<div class="texts" style="color: #1CADF5;">{{correctIndex}}</div>
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<div class="icons" style="background-color: #FF6668;">×</div>
|
|
||||||
<div class="texts" style="color: #FF6668;">{{errorsIndex}}</div>
|
|
||||||
</div>
|
|
||||||
<div @click="dialogVisible=true">
|
<div @click="dialogVisible=true">
|
||||||
<div><span style="color: #1CADF5;">{{questionIndex}}</span>/{{problemData.length}}</div>
|
<div><span style="color: #1CADF5;">{{questionIndex}}</span>/{{problemData.length}}</div>
|
||||||
<div>题号</div>
|
<div>题号</div>
|
||||||
@@ -124,6 +83,7 @@ const { $api,urls , navTo,navBack , vacanciesTo, formatTotal, config } = inject(
|
|||||||
import useUserStore from '@/stores/useUserStore';
|
import useUserStore from '@/stores/useUserStore';
|
||||||
import useDictStore from '@/stores/useDictStore';
|
import useDictStore from '@/stores/useDictStore';
|
||||||
const userInfo = ref({});
|
const userInfo = ref({});
|
||||||
|
const rows = ref({});
|
||||||
const Authorization = ref('');
|
const Authorization = ref('');
|
||||||
const radio = ref('');
|
const radio = ref('');
|
||||||
const radio2 = ref('');
|
const radio2 = ref('');
|
||||||
@@ -131,9 +91,7 @@ const checkList = ref([]);
|
|||||||
const questionIndex = ref(1);
|
const questionIndex = ref(1);
|
||||||
const correctIndex = ref(0);
|
const correctIndex = ref(0);
|
||||||
const errorsIndex = ref(0);
|
const errorsIndex = ref(0);
|
||||||
const accuracyRate = ref(0);
|
|
||||||
const elapsedTime = ref(0);
|
const elapsedTime = ref(0);
|
||||||
const analysis = ref(false);
|
|
||||||
const judgWhether = ref('');
|
const judgWhether = ref('');
|
||||||
const isRunning = ref(false);
|
const isRunning = ref(false);
|
||||||
const dialogVisible = ref(false);
|
const dialogVisible = ref(false);
|
||||||
@@ -149,7 +107,6 @@ watch(questionIndex, (newVal, oldVal) => {
|
|||||||
radio.value=""
|
radio.value=""
|
||||||
radio2.value=""
|
radio2.value=""
|
||||||
checkList.value=[]
|
checkList.value=[]
|
||||||
analysis.value=false
|
|
||||||
judgWhether.value=""
|
judgWhether.value=""
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -161,6 +118,7 @@ watch(questionIndex, (newVal, oldVal) => {
|
|||||||
// });
|
// });
|
||||||
|
|
||||||
onLoad((options) => {
|
onLoad((options) => {
|
||||||
|
rows.value=options
|
||||||
Authorization.value=uni.getStorageSync('Padmin-Token')||''
|
Authorization.value=uni.getStorageSync('Padmin-Token')||''
|
||||||
getHeart();
|
getHeart();
|
||||||
});
|
});
|
||||||
@@ -201,16 +159,57 @@ function queryData(){
|
|||||||
'Authorization':Authorization.value,
|
'Authorization':Authorization.value,
|
||||||
'Content-Type':"application/x-www-form-urlencoded"
|
'Content-Type':"application/x-www-form-urlencoded"
|
||||||
}
|
}
|
||||||
$api.myRequest('/train/public/trainPractice/getQuestions', {
|
if(rows.value.types==1){
|
||||||
userId: userInfo.value.userId
|
$api.myRequest('/train/public/trainExamDash/getExamTopicNoAnswer', {
|
||||||
|
userId: userInfo.value.userId,
|
||||||
|
examPaperId:rows.value.examPaperId
|
||||||
},'post',9100,header).then((resData) => {
|
},'post',9100,header).then((resData) => {
|
||||||
resData.forEach((item,i)=>{
|
if(resData&&resData.code==200){
|
||||||
|
elapsedTime.value=(rows.value.timeLimit*60)
|
||||||
|
resData.data.forEach((item,i)=>{
|
||||||
|
if(item.type=='multiple'){
|
||||||
|
item.choice=[]
|
||||||
|
}else{
|
||||||
|
item.choice=""
|
||||||
|
}
|
||||||
problemData.value.push(item)
|
problemData.value.push(item)
|
||||||
problemList.value.push({index:i+1,whether:""})
|
problemList.value.push({index:i+1,whether:""})
|
||||||
})
|
})
|
||||||
start()
|
start()
|
||||||
accuracyRates()
|
}
|
||||||
});
|
});
|
||||||
|
}else if(rows.value.types==2){
|
||||||
|
$api.myRequest('/train/public/trainExamDash/continueExam', {
|
||||||
|
userId: userInfo.value.userId,
|
||||||
|
examPaperId:rows.value.examPaperId
|
||||||
|
},'post',9100,header).then((resData) => {
|
||||||
|
if(resData&&resData.code==200){
|
||||||
|
elapsedTime.value=(rows.value.timeLimit*60)
|
||||||
|
resData.data.forEach((item,i)=>{
|
||||||
|
if(item.type=='multiple'){
|
||||||
|
if(item.choosed){
|
||||||
|
item.choice=item.choosed.split(",");
|
||||||
|
item.submitAnswers=true
|
||||||
|
}else{
|
||||||
|
item.choice=[]
|
||||||
|
item.submitAnswers=false
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if(item.choosed){
|
||||||
|
item.choice=item.choosed;
|
||||||
|
item.submitAnswers=true
|
||||||
|
}else{
|
||||||
|
item.choice=""
|
||||||
|
item.submitAnswers=false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
problemData.value.push(item)
|
||||||
|
problemList.value.push({index:i+1,whether:""})
|
||||||
|
})
|
||||||
|
start()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
function collect(is){
|
function collect(is){
|
||||||
let header={
|
let header={
|
||||||
@@ -225,76 +224,102 @@ function collect(is){
|
|||||||
problemData.value[questionIndex.value-1].isCollect=is
|
problemData.value[questionIndex.value-1].isCollect=is
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
//正确率
|
|
||||||
function accuracyRates(){
|
|
||||||
let header={
|
|
||||||
'Authorization':Authorization.value,
|
|
||||||
'Content-Type':"application/x-www-form-urlencoded"
|
|
||||||
}
|
|
||||||
$api.myRequest('/train/public/trainPractice/getCount', {
|
|
||||||
userId: userInfo.value.userId,
|
|
||||||
},'post',9100,header).then((resData) => {
|
|
||||||
accuracyRate.value=resData.truePresent
|
|
||||||
});
|
|
||||||
};
|
|
||||||
//提交答案
|
//提交答案
|
||||||
function submit(){
|
function submit(){
|
||||||
let indexs=questionIndex.value-1
|
let indexs=questionIndex.value-1
|
||||||
let parm={
|
let parm={
|
||||||
|
examPaperId:rows.value.examPaperId,
|
||||||
questionId:problemData.value[indexs].questionId,
|
questionId:problemData.value[indexs].questionId,
|
||||||
userId:userInfo.value.userId,
|
userId:userInfo.value.userId,
|
||||||
answer:problemData.value[indexs].answer
|
answer:problemData.value[indexs].type=='multiple'?problemData.value[indexs].choice.join(","):problemData.value[indexs].choice,
|
||||||
}
|
examId:problemData.value[indexs].examId
|
||||||
if(problemData.value[indexs].type=='single'){
|
|
||||||
parm.submitAnswer=radio.value
|
|
||||||
}else if(problemData.value[indexs].type=='multiple'){
|
|
||||||
parm.submitAnswer=checkList.value.join(',')
|
|
||||||
}else if(problemData.value[indexs].type=='judge'){
|
|
||||||
parm.submitAnswer=radio2.value
|
|
||||||
}
|
}
|
||||||
let header={
|
let header={
|
||||||
'Authorization':Authorization.value,
|
'Authorization':Authorization.value,
|
||||||
'Content-Type':"application/json"
|
'Content-Type':"application/x-www-form-urlencoded"
|
||||||
}
|
}
|
||||||
$api.myRequest('/train/public/trainPractice/submitAnswer', parm,'post',9100,header).then((resData) => {
|
$api.myRequest('/train/public/trainExamDash/submitAnswer', parm,'post',9100,header).then((resData) => {
|
||||||
if(resData&&resData.code==200){
|
if(resData&&resData.code==200){
|
||||||
analysis.value=true
|
problemData.value[indexs].submitAnswers=true
|
||||||
judgWhether.value=resData.msg
|
if(problemData.value.length==questionIndex.value){
|
||||||
problemList.value[indexs].whether=resData.msg
|
$api.msg('已经是最后一题了,请仔细检查后交卷!')
|
||||||
if(resData.msg=='正确'){
|
}else{
|
||||||
correctIndex.value++
|
questionIndex.value+=1
|
||||||
}else if(resData.msg=='错误'){
|
|
||||||
errorsIndex.value++
|
|
||||||
}
|
}
|
||||||
accuracyRates()
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
function selected(i){
|
//完成练习
|
||||||
radio.value=i
|
function complete(){
|
||||||
|
let arr=[]
|
||||||
|
problemData.value.forEach((item,index)=>{
|
||||||
|
if(!item.submitAnswers){
|
||||||
|
arr.push(index+1)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
wx.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: (arr.length>0?'第'+arr.join(",")+'题还未作答,':'请仔细检查试卷 ,')+'确认是否交卷?',
|
||||||
|
success (res) {
|
||||||
|
if (res.confirm) {
|
||||||
|
onpaper()
|
||||||
|
} else if (res.cancel) {
|
||||||
|
console.log('用户点击取消')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
function onpaper(){
|
||||||
|
let indexs=questionIndex.value-1
|
||||||
|
let parm={
|
||||||
|
examPaperId:rows.value.examPaperId,
|
||||||
|
userId:userInfo.value.userId,
|
||||||
|
examId:problemData.value[indexs].examId,
|
||||||
|
useTime:(rows.value.timeLimit*60) - elapsedTime.value,
|
||||||
|
}
|
||||||
|
let header={
|
||||||
|
'Authorization':Authorization.value,
|
||||||
|
'Content-Type':"application/x-www-form-urlencoded"
|
||||||
|
}
|
||||||
|
$api.myRequest('/train/public/trainExamDash/submitExam', parm,'post',9100,header).then((resData) => {
|
||||||
|
if(resData&&resData.code==200){
|
||||||
|
$api.msg('提交成功!')
|
||||||
|
navBack()
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
function selected(i,index){
|
||||||
|
problemData.value[index].choice=i
|
||||||
|
problemData.value=JSON.parse(JSON.stringify(problemData.value))
|
||||||
};
|
};
|
||||||
//多选
|
//多选
|
||||||
function selected2(i){
|
function selected2(i,indexs){
|
||||||
let arr=checkList.value.join(",")
|
let arr=problemData.value[indexs].choice.join(",")
|
||||||
if(arr.indexOf(i) !== -1){
|
if(arr.indexOf(i) !== -1){
|
||||||
const index = checkList.value.indexOf(i);
|
const index = problemData.value[indexs].choice.indexOf(i);
|
||||||
if (index !== -1) {
|
if (index !== -1) {
|
||||||
checkList.value.splice(index, 1);
|
problemData.value[indexs].choice.splice(index, 1);
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
checkList.value.push(i)
|
problemData.value[indexs].choice.push(i)
|
||||||
}
|
}
|
||||||
|
problemData.value=JSON.parse(JSON.stringify(problemData.value))
|
||||||
};
|
};
|
||||||
function judgment(i){
|
function judgment(i,indexs){
|
||||||
let arr=checkList.value.join(",")
|
let arr=problemData.value[indexs].choice.join(",")
|
||||||
if(arr.indexOf(i) !== -1){
|
if(arr.indexOf(i) !== -1){
|
||||||
return true
|
return true
|
||||||
}else{
|
}else{
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
function selected3(i){
|
function selected3(i,index){
|
||||||
radio2.value=i
|
// radio2.value=i
|
||||||
|
problemData.value[index].choice=i
|
||||||
|
problemData.value=JSON.parse(JSON.stringify(problemData.value))
|
||||||
};
|
};
|
||||||
// 解析选项
|
// 解析选项
|
||||||
function parseOptions(options) {
|
function parseOptions(options) {
|
||||||
@@ -320,14 +345,16 @@ function start() {
|
|||||||
if (isRunning.value) return
|
if (isRunning.value) return
|
||||||
isRunning.value = true
|
isRunning.value = true
|
||||||
timer = setInterval(() => {
|
timer = setInterval(() => {
|
||||||
elapsedTime.value++
|
elapsedTime.value-=1
|
||||||
|
if(elapsedTime.value==0){
|
||||||
|
// this.$message({
|
||||||
|
// message: '考试时间已结束,系统将自动交卷',
|
||||||
|
// type: 'warning'
|
||||||
|
// });
|
||||||
|
onpaper()
|
||||||
|
}
|
||||||
}, 1000)
|
}, 1000)
|
||||||
};
|
};
|
||||||
function pause() {
|
|
||||||
if (!isRunning.value) return
|
|
||||||
clearInterval(timer)
|
|
||||||
isRunning.value = false
|
|
||||||
};
|
|
||||||
function clones(){
|
function clones(){
|
||||||
dialogVisible.value=false
|
dialogVisible.value=false
|
||||||
};
|
};
|
||||||
@@ -336,7 +363,17 @@ function switchs(i){
|
|||||||
dialogVisible.value=false
|
dialogVisible.value=false
|
||||||
};
|
};
|
||||||
function exit(){
|
function exit(){
|
||||||
|
wx.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: '直接退出是不计分的, 确定要退出吗?',
|
||||||
|
success (res) {
|
||||||
|
if (res.confirm) {
|
||||||
navBack()
|
navBack()
|
||||||
|
} else if (res.cancel) {
|
||||||
|
console.log('用户点击取消')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
@@ -360,15 +397,16 @@ function exit(){
|
|||||||
padding: 20rpx 28rpx;
|
padding: 20rpx 28rpx;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
.header{
|
.header{
|
||||||
height: 100rpx;
|
height: 110rpx;
|
||||||
padding: 0 10rpx;
|
padding: 10rpx 10rpx 0;
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
background: linear-gradient(0deg, #4285EC 0%, #0BBAFB 100%);
|
background: linear-gradient(0deg, #4285EC 0%, #0BBAFB 100%);
|
||||||
color: #fff;
|
color: #fff;
|
||||||
font-size: 26rpx;
|
font-size: 26rpx;
|
||||||
border-radius: 10rpx
|
border-radius: 10rpx
|
||||||
|
.headerCon{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-between;
|
||||||
.headBtn{
|
.headBtn{
|
||||||
background: #499FFF;
|
background: #499FFF;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
@@ -378,6 +416,8 @@ function exit(){
|
|||||||
line-height: 50rpx;
|
line-height: 50rpx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
.problemCard{
|
.problemCard{
|
||||||
margin-top: 30rpx;
|
margin-top: 30rpx;
|
||||||
.problemTitle{
|
.problemTitle{
|
||||||
|
|||||||
@@ -2,20 +2,69 @@
|
|||||||
<div class="app-box">
|
<div class="app-box">
|
||||||
<div class="con-box">
|
<div class="con-box">
|
||||||
<div class="tabCon">
|
<div class="tabCon">
|
||||||
|
<template v-for="(item,index) in gradeData">
|
||||||
<div class="tabLeft">
|
<div class="tabLeft">
|
||||||
<div><span>考试名称:</span>456546456</div>
|
<div><span>考试名称:</span>{{item.name}}</div>
|
||||||
<div><span>考试时间:</span>456546456</div>
|
<div><span>考试时间:</span>{{item.createTime}}</div>
|
||||||
<div><span>考试成绩:</span>456546456</div>
|
<div><span>考试成绩:</span>{{item.score}}分</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="tabRight">查看</div>
|
<div class="tabRight" @click="detail(item)">查看</div>
|
||||||
<div class="tabLeft"></div>
|
</template>
|
||||||
<div class="tabRight">查看</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script setup>
|
||||||
|
import { reactive, inject, watch, ref, onMounted,onBeforeUnmount,computed } from 'vue';
|
||||||
|
import { onLoad, onShow } from '@dcloudio/uni-app';
|
||||||
|
const { $api,urls , navTo,navBack , vacanciesTo, formatTotal, config } = inject('globalFunction');
|
||||||
|
import useUserStore from '@/stores/useUserStore';
|
||||||
|
import useDictStore from '@/stores/useDictStore';
|
||||||
|
const userInfo = ref({});
|
||||||
|
const rows = ref({});
|
||||||
|
const Authorization = ref('');
|
||||||
|
const gradeData = ref([]);
|
||||||
|
onLoad((options) => {
|
||||||
|
rows.value=options
|
||||||
|
Authorization.value=uni.getStorageSync('Padmin-Token')||''
|
||||||
|
getHeart();
|
||||||
|
});
|
||||||
|
function getHeart() {
|
||||||
|
const raw =Authorization.value;
|
||||||
|
const token = typeof raw === "string" ? raw.trim() : "";
|
||||||
|
const headers = token ? { 'Authorization': raw.startsWith("Bearer ") ? raw : `Bearer ${token}` }: {}
|
||||||
|
$api.myRequest("/dashboard/auth/heart", {}, "POST", 10100, headers).then((resData) => {
|
||||||
|
if (resData.code == 200) {
|
||||||
|
getUserInfo();
|
||||||
|
} else {
|
||||||
|
navTo('/packageB/login')
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
function getUserInfo(){
|
||||||
|
let header={
|
||||||
|
'Authorization':Authorization.value
|
||||||
|
}
|
||||||
|
$api.myRequest('/system/user/login/user/info', {},'get',10100,header).then((resData) => {
|
||||||
|
userInfo.value = resData.info || {};
|
||||||
|
// userId.value=resData.info.userId
|
||||||
|
queryData()
|
||||||
|
});
|
||||||
|
};
|
||||||
|
function queryData(){
|
||||||
|
$api.myRequest('/train/public/trainExamDash/getExamByIdTable', {
|
||||||
|
userId:userInfo.value.userId,
|
||||||
|
examPaperId:rows.value.examPaperId,
|
||||||
|
}).then((resData) => {
|
||||||
|
if(resData&&resData.code==200){
|
||||||
|
gradeData.value=resData.rows
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function detail(row){
|
||||||
|
navTo('/packageB/train/mockExam/paperDetails?examPaperId='+row.examPaperId+'&examId='+row.examId+'&name='+row.name);
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="stylus" scoped>
|
<style lang="stylus" scoped>
|
||||||
@@ -40,17 +89,21 @@
|
|||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
.tabLeft{
|
.tabLeft{
|
||||||
width: 80%;
|
width: 80%;
|
||||||
height: 140rpx;
|
height: 150rpx;
|
||||||
border-bottom: 1px solid #ccc;
|
border-bottom: 1px solid #ccc;
|
||||||
border-right: 1px solid #ccc;
|
border-right: 1px solid #ccc;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
view{
|
view{
|
||||||
line-height: 45rpx
|
line-height: 45rpx
|
||||||
|
color: #2175F3;
|
||||||
|
label{
|
||||||
|
color: #666;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.tabRight{
|
.tabRight{
|
||||||
width: 20%;
|
width: 20%;
|
||||||
height: 140rpx;
|
height: 150rpx;
|
||||||
border-bottom: 1px solid #ccc;
|
border-bottom: 1px solid #ccc;
|
||||||
border-right: 1px solid #ccc;
|
border-right: 1px solid #ccc;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
|||||||
@@ -273,6 +273,9 @@ function submit(){
|
|||||||
}else if(resData.msg=='错误'){
|
}else if(resData.msg=='错误'){
|
||||||
errorsIndex.value++
|
errorsIndex.value++
|
||||||
}
|
}
|
||||||
|
if(questionIndex.value==problemData.value.length){
|
||||||
|
$api.msg('已经是最后一题了,请点击 “完成练习” 按钮保存记录')
|
||||||
|
}
|
||||||
accuracyRates()
|
accuracyRates()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -343,8 +346,22 @@ function switchs(i){
|
|||||||
dialogVisible.value=false
|
dialogVisible.value=false
|
||||||
};
|
};
|
||||||
function exit(){
|
function exit(){
|
||||||
|
let header={
|
||||||
|
'Authorization':Authorization.value,
|
||||||
|
'Content-Type':"application/x-www-form-urlencoded"
|
||||||
|
}
|
||||||
|
$api.myRequest('/train/public/trainPractice/getCount', {
|
||||||
|
userId: userInfo.value.userId,
|
||||||
|
title:"专项练习",
|
||||||
|
type:"practice",
|
||||||
|
hour:elapsedTime.value,
|
||||||
|
truePresent:accuracyRate.value
|
||||||
|
},'post',9100,header).then((resData) => {
|
||||||
|
if(resData&&resData.code==200){
|
||||||
navBack()
|
navBack()
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="stylus" scoped>
|
<style lang="stylus" scoped>
|
||||||
|
|||||||
@@ -312,6 +312,12 @@
|
|||||||
"navigationBarTitleText": "查看成绩"
|
"navigationBarTitleText": "查看成绩"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"path": "train/mockExam/paperDetails",
|
||||||
|
"style": {
|
||||||
|
"navigationBarTitleText": "考试详情"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"path": "priority/helpFilter",
|
"path": "priority/helpFilter",
|
||||||
"style": {
|
"style": {
|
||||||
|
|||||||
Reference in New Issue
Block a user