[测评系统]--前端(用户答题页面)
zhijie
2023-12-04 887e0b1473e995e8ae55b400d540ccc41efb145a
src/views/exam/paper/career_interests.vue
@@ -1,8 +1,8 @@
<template>
  <div>
    <el-container  class="app-item-contain">
      <el-header class="align-center" v-if="guide">
        <h1></h1>
    <el-container  class="app-item-contain is-vertical">
      <el-header class="align-center" v-if="guide" style="height: 50px;padding: 1%;margin-top: 4%">
        <H2 v-html="$t('guide')"></H2>
      </el-header>
      <el-main style="padding-top: 3%;">
        <div v-html="guideDescirption" v-if="guide" :style="ismobile?'padding-top: 2%;margin-top: 5%;':'padding-top: 2%;margin: 0 auto;width:66%'"></div>
@@ -17,10 +17,11 @@
              <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>
              <div style="color: red;font-size: smaller" v-if="partOrder == 1">{{$t('pleaseAnswerCarefullyCiaq')}}</div>
              <div style="color: red;font-size: smaller" v-if="partOrder != 1">{{$t('pleaseAnswerCarefully')}}</div>
              <el-row class="do-align-center" v-if="order < problemLength">
            <el-button @click="preSubject" type="warning"  v-if ="preDisable" round>{{$t('lastQuestion')}}</el-button>
            <el-button @click="nextSubject" type="primary" v-if ="nextDisable" round>{{$t('nextQuestion')}}</el-button>
@@ -61,7 +62,7 @@
import examPaperAnswerApi from '@/api/examPaperAnswer'
import demographyApi from '@/api/demography'
export default {
  name: 'personality',
  name: 'career_interests',
  components: { QuestionEdit },
  data () {
    return {
@@ -117,9 +118,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 +148,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
@@ -187,6 +196,7 @@
      ).catch(e => {
      })
    }
    console.log(' _this.partOrder:'+_this.partOrder)
  },
  mounted () {
  },
@@ -247,6 +257,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() !== ''