提交 #1

Merged
huxiaofeng666 merged 1 commits from dev-hxf into master 1 year ago
  1. 16
      .hbuilderx/launch.json
  2. 414
      src/pages/questionBank/components/Question.vue

@ -0,0 +1,16 @@
{ // launch.json configurations app-plus/h5/mp-weixin/mp-baidu/mp-alipay/mp-qq/mp-toutiao/mp-360/
// launchtypelocalremote, localremote
"version": "0.0",
"configurations": [{
"default" :
{
"launchtype" : "local"
},
"mp-weixin" :
{
"launchtype" : "local"
},
"type" : "uniCloud"
}
]
}

@ -1,27 +1,52 @@
<template> <template>
<view style="margin-top: 100px;"> <view style="margin-top: 100px;">
<view class="flex ai-c jc-c"> <view class="flex ai-c jc-c">
<view class="flex type_box"> <view class="flex type_box jc-sb ai-c">
<view class="type_item" :class="tCurrent==0?'checked':'unchecked'" @tap="sectionChange(0)">答题</view> <view class="type_item" :class="tCurrent==0?'checked':'unchecked'" @tap="sectionChange(0)">答题</view>
<view class="type_item" :class="tCurrent==1?'checked':'unchecked'" @tap="sectionChange(1)">背题</view> <view class="type_item" :class="tCurrent==1?'checked':'unchecked'" @tap="sectionChange(1)">背题</view>
</view> </view>
</view> </view>
<swiper class="swiper" :current="swiperIndex" :duration="duration" :autoplay="false" :disable-programmatic-animation="true" @change="onChange" @animationfinish="onAnimationfinish">
<swiper-item v-for="(quesItem,quesIndex) in swiperList" :key="quesIndex">
<scroll-view scroll-y="true" class="swiper-scroll">
<view>
<view class="m14lr"> <view class="m14lr">
<text class="tag_box">{{questionList[currentIndex].questionTypeDesc}}</text> <text class="tag_box">{{quesItem.questionTypeDesc}}</text>
<text class="fs18">{{questionList[currentIndex].questionDesc}}</text> <text class="fs18">{{quesItem.questionDesc}}</text>
</view> </view>
<view class="flex m14lr ai-c mt20" v-for="(item,index) in questionList[currentIndex].optionList" :key="item.op"> <view class="flex m14lr ai-c mt20" v-for="(item,index) in quesItem.optionList"
<template v-if="clickAnswer&&item.op===questionList[currentIndex].rightAnswer"> :key="item.op" @tap="answerQues(item.op,index)">
<u-icon name="checkmark-circle-fill" color="#05C341" size="30"></u-icon> <template
v-if="quesItem.clickAnswer&&item.op===quesItem.rightOp">
<u-icon class="mr15" name="checkmark-circle-fill" color="#05C341" size="30"></u-icon>
</template> </template>
<template v-else-if="clickAnswer===item.op&&item.op!==questionList[currentIndex].rightAnswer"> <template
<u-icon name="close-circle-fill" color="red" size="30"></u-icon> v-else-if="quesItem.clickAnswer===item.op&&item.op!==quesItem.rightAnswer">
<u-icon class="mr15" name="close-circle-fill" color="red" size="30"></u-icon>
</template> </template>
<template v-else-if="!clickAnswer"> <template v-else-if="!item.chooseOption">
<view class="option_item">{{item.op}}</view> <view class="option_item">{{item.op}}</view>
</template> </template>
<text class="fs18">{{item.opDesc}}</text> <text class="fs18">{{item.opDesc}}</text>
</view> </view>
<view class="m14lr mt30"
v-if="quesItem.clickAnswer&&quesItem.clickAnswer!==quesItem.rightOp || tCurrent===1">
<view class="answer_box">
<text class="fs18 fw600 cor-000">答案:{{quesItem.rightOp}}</text>
<view class="fs18 cor-000" style="text-indent:2em;"> 这里是相关解释文字这里是相关解释文字相关解释文字</view>
</view>
</view>
</view>
</scroll-view>
</swiper-item>
</swiper>
<u-modal :show="tipShow" :title="title" :content="content">
<template #confirmButton>
<view class="p10" >
<u-button :customStyle="{width:'100%',height:'68rpx',borderRadius:'34rpx'}">查看练题结果</u-button>
</view>
</template>
</u-modal>
</view> </view>
</template> </template>
@ -29,24 +54,114 @@
export default { export default {
data() { data() {
return { return {
content:'太棒啦,已答完最后一题',
tipShow:false,
title:'提示',
tCurrent:0, tCurrent:0,
clickAnswer:undefined, questionList: [],//
questionList:[], swiperList: [], //
currentIndex:0, swiperIndex: 0, //
isChange: false, //
topicIndex: 0, //
duration: 200, //
} }
}, },
onshow(){ onLoad() {
this.getQuestionList() this.getQuestionList()
this.renderSwiper(0)
}, },
methods: { methods: {
// swiper
renderSwiper(index) {
let list = [];
let current = 1;
if (this.questionList[index - 1]) {
list.push(this.questionList[index - 1]);
} else {
current = 0;
}
list.push(this.questionList[index])
if (this.questionList[index + 1]) {
list.push(this.questionList[index + 1]);
}
this.duration = 0;
setTimeout(() => {
this.swiperList = list;
this.swiperIndex = current;
setTimeout(() => {
this.duration = 200;
}, 100)
}, 50)
},
//
onChange(e) {
//
if (e.detail.source != "touch") return;
//
this.isChange = true;
//
if (e.detail.current > this.swiperIndex) {
this.topicIndex++;
} else {
//
this.topicIndex--;
}
// Vue
this.swiperIndex = e.detail.current;
},
//
onAnimationfinish(e) {
if (!this.isChange) return;
this.isChange = false;
setTimeout(() => {
this.renderSwiper(this.topicIndex);
}, 10);
},
//
pickerTopic(index) {
this.topicIndex = index;
this.renderSwiper(index);
},
//
answerQues(op, index) {
if (!this.questionList[this.topicIndex].clickAnswer) {
this.questionList[this.topicIndex].optionList[index].chooseOption = op
this.questionList[this.topicIndex].clickAnswer = op
}
if(this.tCurrent!==1){
if(this.questionList[this.topicIndex].clickAnswer===this.questionList[this.topicIndex].rightOp){
if(this.topicIndex<=this.questionList.length-1){
if(this.topicIndex===this.questionList.length-1){
this.tipShow=true
}else{
this.tipShow=false
}
this.topicIndex ++;
setTimeout(()=>{
this.renderSwiper(this.topicIndex);
},1000)
}
}
}
},
sectionChange(index) { sectionChange(index) {
this.tCurrent = index this.tCurrent = index
this.getQuestionList()
this.renderSwiper(0)
}, },
getQuestionList() { getQuestionList() {
this.questionList = [{ this.questionList = [{
questionId: 0, questionId: 0,
questionTypeDesc: '单选', questionTypeDesc: '单选',
questionDesc:'在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?', questionDesc: '第一题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{ optionList: [{
op: 'A', op: 'A',
opDesc: '注意新手标志' opDesc: '注意新手标志'
@ -63,7 +178,8 @@
rightOp: 'C', rightOp: 'C',
}, { }, {
questionId: 1, questionId: 1,
questionDesc:'在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?', questionTypeDesc: '单选',
questionDesc: '第二题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{ optionList: [{
op: 'A', op: 'A',
opDesc: '注意新手标志' opDesc: '注意新手标志'
@ -80,7 +196,154 @@
rightOp: 'B', rightOp: 'B',
}, { }, {
questionId: 2, questionId: 2,
questionDesc:'在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?', questionTypeDesc: '单选',
questionDesc: '第三题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
},
{
questionId: 3,
questionTypeDesc: '单选',
questionDesc: '第四题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 4,
questionTypeDesc: '单选',
questionDesc: '第5题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
},
{
questionId: 5,
questionTypeDesc: '单选',
questionDesc: '第6题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 6,
questionTypeDesc: '单选',
questionDesc: '第7题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 7,
questionTypeDesc: '单选',
questionDesc: '第8题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 8,
questionTypeDesc: '单选',
questionDesc: '第9题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'C',
}, {
questionId: 9,
questionTypeDesc: '单选',
questionDesc: '第10题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'B',
}, {
questionId: 10,
questionTypeDesc: '单选',
questionDesc: '第11题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{ optionList: [{
op: 'A', op: 'A',
opDesc: '注意新手标志' opDesc: '注意新手标志'
@ -95,7 +358,108 @@
opDesc: '注意新手标志' opDesc: '注意新手标志'
}], }],
rightOp: 'A', rightOp: 'A',
}] },
{
questionId: 11,
questionTypeDesc: '单选',
questionDesc: '第12题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 12,
questionTypeDesc: '单选',
questionDesc: '第13题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
},
{
questionId: 13,
questionTypeDesc: '单选',
questionDesc: '第14题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 14,
questionTypeDesc: '单选',
questionDesc: '第15题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}, {
questionId: 15,
questionTypeDesc: '单选',
questionDesc: '第16题,在实习期内驾驶机动车的,应当在车身后部粘贴或者悬挂哪种标志?',
optionList: [{
op: 'A',
opDesc: '注意新手标志'
}, {
op: 'B',
opDesc: '注意新手标志'
}, {
op: 'C',
opDesc: '注意新手标志'
}, {
op: 'D',
opDesc: '注意新手标志'
}],
rightOp: 'A',
}
]
if(this.tCurrent===1){
this.questionList=this.questionList.map(item=>{
return{
...item,
clickAnswer:item.rightOp
}
})
}
} }
} }
} }
@ -108,6 +472,7 @@
background-color: #FFFFFF; background-color: #FFFFFF;
border-radius: 8rpx; border-radius: 8rpx;
} }
.type_item { .type_item {
text-align: center; text-align: center;
line-height: 64rpx; line-height: 64rpx;
@ -115,13 +480,16 @@
height: 64rpx; height: 64rpx;
border-radius: 8rpx; border-radius: 8rpx;
} }
.checked { .checked {
color: #fff; color: #fff;
background-color: #05C341; background-color: #05C341;
} }
.unchecked { .unchecked {
color: #666; color: #666;
} }
.tag_box { .tag_box {
display: inline-block; display: inline-block;
width: 78rpx; width: 78rpx;
@ -134,6 +502,7 @@
font-size: 12px; font-size: 12px;
margin-right: 5px; margin-right: 5px;
} }
.option_item { .option_item {
width: 60rpx; width: 60rpx;
height: 60rpx; height: 60rpx;
@ -143,4 +512,15 @@
line-height: 60rpx; line-height: 60rpx;
margin-right: 30rpx; margin-right: 30rpx;
} }
.swiper {
height: 100vh;
}
.answer_box {
width: 100%;
padding: 30rpx;
background: #EEEEEE;
border-radius: 20rpx;
}
</style> </style>

Loading…
Cancel
Save