[测评系统]--前端(用户答题页面)
linzhijie
2023-05-10 3549b2fd37fe56a1c5cddd626ce53a5d720d4d0a
src/views/exam/paper/career_interests.vue
@@ -5,7 +5,7 @@
        <h1></h1>
      </el-header>
      <el-main style="padding-top: 3%;">
        <div v-html="guideDescirption" v-if="guide" :style="ismobile?'padding-top: 2%;':'padding-top: 2%;margin: 0 auto;width:66%'"></div>
        <div v-html="guideDescirption" v-if="guide" :style="ismobile?'padding-top: 2%;margin-top: 5%;':'padding-top: 2%;margin: 0 auto;width:66%'"></div>
        <el-row class="do-align-center" v-if="guide">
          <el-button @click="startDo" type="primary" :disable="startDoDisable">{{$t('start')}}</el-button>
        </el-row >
@@ -17,7 +17,7 @@
              <hr style="border : 1px dashed #b3d8ff;" />
              <el-form-item :key="itemOrder" label-width="1px">
                <QuestionEdit @callNextSubject="nextSubject" :qType="questionItem.questionType" :question="questionItem"
                              :answer="answer.answerItems[questionItem.itemOrder-1]" :qLabel="itemOrder+'/'+itemSize"/>
                              :answer="answer.answerItems[questionItem.itemOrder-1]" :qLabel="questionItem.serialNumber+'/'+questionItem.serialNumberCount"/>
              </el-form-item>
              <hr style="border : 0.5px dashed #b3d8ff;" />
              <div style="color: red;font-size: smaller">{{$t('pleaseAnswerCarefully')}}</div>
@@ -60,9 +60,8 @@
import examPaperApi from '@/api/examPaper'
import examPaperAnswerApi from '@/api/examPaperAnswer'
import demographyApi from '@/api/demography'
export default {
  name: 'personality',
  name: 'career_interests',
  components: { QuestionEdit },
  data () {
    return {
@@ -94,6 +93,7 @@
      guideTitle: '',
      guideDescirption: '',
      isCallTain: '',
      isSignalObject: '',
      memberName: '',
      itemSize: '', // 题目长度
      startDoDisable: true,
@@ -117,9 +117,16 @@
      _this.itemOrder = _this.form.titleItems[0].questionItems[0].itemOrder
      _this.timeReduce()
      _this.initAnswer()
      _this.initPartSize()
      _this.formLoading = false
      _this.memberName = _this.form.memberName
      _this.itemSize = _this.form.titleItems[0].questionItems.length
      // 展示指导语
      if (_this.form.parts[0].signals.length !== 0) {
        console.log('首题提示语')
        _this.showNextGuide(_this.form.parts[0].signals[0], false)
      }
    } else {
      _this.formLoading = true
      // 防止刷新成了不同的语言
@@ -140,6 +147,7 @@
            _this.questionItem = _this.form.titleItems[0].questionItems[_this.order]
            _this.partOrder = _this.questionItem.partOrder
            _this.initAnswer()
            _this.initPartSize()
            _this.formLoading = false
            _this.memberName = _this.form.memberName
@@ -247,6 +255,36 @@
        }
      }
    },
    initPartSize: function () {
      // 初始化题目序号  每个分片从0开始
      let _this = this
      let serialNumber = 1
      let partOrder = 1
      for (let i = 0; i < _this.form.titleItems[0].questionItems.length; i++) {
        if (_this.form.titleItems[0].questionItems[i].partOrder === partOrder) {
          _this.form.titleItems[0].questionItems[i].serialNumber = serialNumber
          _this.form.titleItems[0].questionItems[i].serialNumberCount = _this.getPartCount(partOrder)
          serialNumber++
        } else {
          partOrder = _this.form.titleItems[0].questionItems[i].partOrder
          serialNumber = 1
          _this.form.titleItems[0].questionItems[i].serialNumber = serialNumber
          _this.form.titleItems[0].questionItems[i].serialNumberCount = _this.getPartCount(partOrder)
          serialNumber++
        }
      }
    },
    getPartCount: function (partOrder) {
      // 数据统计
      let _this = this
      let sum = 0
      _this.form.titleItems[0].questionItems.forEach(function (elem, index) {
        if (elem.partOrder === partOrder) {
          sum += 1
        }
      })
      return sum
    },
    isContentNotEmpty: function (num) {
      let _this = this
      return _this.answer.answerItems[num].content !== '' && _this.answer.answerItems[num].content !== null && _this.answer.answerItems[num].content.trim() !== ''
@@ -265,7 +303,13 @@
      if (_this.partOrder !== nowPartOrder) {
        _this.isShowGuide(true)
      }
      _this.preDisable = true
      // 如果上一题不是本段,则不能返回上一段
      if (this.isDiffPartOrder()) {
        _this.preDisable = false
      } else {
        _this.preDisable = true
      }
      _this.nextDisable = false
      _this.answer.answerItems[_this.order].startTime = _this.formatDate(new Date(), 'yyyy-MM-dd hh:mm:ss')
@@ -294,6 +338,9 @@
    },
    catThaiSubmit: function (answerSubmit) {
      answerSubmit.isCallTain = 'CallThai'
    },
    setSignalObject: function (answerSubmit) {
      answerSubmit.isSignalObject = 'CIAQ'
    },
    getEmptySubjct: function (order) {
      let _this = this
@@ -344,10 +391,15 @@
      }
      this.answer.answerItems[_this.order].readOnly = true
      let answerSubmit = _this.getSubmitAnswerValue(nowPartOrder)
      console.log(answerSubmit)
      // 已经答到了最后一题了,不用自动跳到下一题
      if (this.order + 1 > this.problemLength) {
        this.submitDisable = false
        return
      }
      // 如果是最后一题就上面提交了,不会走到这里
      if (this.isNextShowGuide(nowPartOrder)) {
        this.setSignalObject(answerSubmit)
      }
      examPaperAnswerApi.answerSubmit(answerSubmit, _this.memberToken).then(re => {
        if (re.code !== 1) {
@@ -378,6 +430,7 @@
      })
      answerSubmit.langType = _this.langType
      answerSubmit.isCallTain = _this.isCallTain
      answerSubmit.isSignalObject = _this.isSignalObject
      answerSubmit.partOrder = nowPartOrder
      answerSubmit.itemOrder = _this.itemOrder
      return answerSubmit
@@ -386,6 +439,13 @@
      let _this = this
      _this.isShowGuide(false)
      if (_this.order > 0) {
        // 清空本题的选择
        _this.answer.answerItems[_this.order].content = null
        _this.answer.answerItems[_this.order].completed = false
        _this.answer.answerItems[_this.order].questionReport = null
        _this.answer.answerItems[_this.order].readOnly = false
        // 设置回到上一题
        let num = --_this.order
        _this.itemOrder = _this.form.titleItems[0].questionItems[num].itemOrder
        _this.questionItem = _this.form.titleItems[0].questionItems[num]
@@ -426,13 +486,14 @@
      } else {
        _this.answer.verifyStatus = 1
        _this.answer.finish = 1
        _this.submitAnswer(_this.$t('finishPersonalityInfo'))
        _this.submitAnswer(_this.$t('finishCareerInterestsInfo'))
      }
    },
    startDo: function () {
      let _this = this
      _this.guide = false
      _this.isCallTain = ''
      _this.isSignalObject = ''
    },
    submitAnswer: function (mess) {
      let _this = this
@@ -448,7 +509,7 @@
      examPaperAnswerApi.answerSubmit(answerSubmit, _this.memberToken).then(re => {
        loading.close()
        if (re.code === 1) {
          _this.$router.push({ path: '/exam/finish', query: { name: _this.form.name, content: mess, tokenId: _this.memberToken } })
          _this.$router.push({ path: '/exam/finish', query: { name: _this.form.name, content: mess, tokenId: _this.memberToken, type: 'CIAQ' } })
        } else {
          _this.$message.error(re.message + '/exam/finish')
        }