龚焕茏
2024-07-02 54730b188630e71ac9ee4044a4b9be160072d0d1
feat:新增考试记录题目查看
3个文件已修改
1个文件已添加
749 ■■■■ 已修改文件
src/views/answer/MarkPaperShow.vue 191 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/answer/components/QuestionAnswerShow.vue 126 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/answer/detail.vue 430 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/answer/info.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/answer/MarkPaperShow.vue
New file
@@ -0,0 +1,191 @@
<template>
  <div v-loading="qLoading" style="line-height:1.8">
    <div
      v-if="qType == 1 || qType == 2 || qType == 3 || qType == 4 || qType == 5 || qType == 6 || qType == 7 || qType == 8">
      <!-- 选择或语音 -->
      <div v-if="qType == 1 || qType == 6">
        <div class="q-title" v-html="question.title"/>
        <div class="q-content">
          <el-radio-group v-model="question.answer">
            <el-radio class="custom-radio" v-for="item in question.questionItemList" :key="item.prefix" :label="item.prefix " disabled>
              <span class="question-prefix">{{ item.prefix }}.</span>
              <span v-html="item.content" class="q-item-span-content"></span>
            </el-radio>
          </el-radio-group>
        </div>
      </div>
      <!-- 多选 -->
      <div v-else-if="qType == 2">
        <div class="q-title" v-html="question.title"/>
        <div class="q-content">
          <el-checkbox-group v-model="question.answerList">
            <el-checkbox v-for="item in question.questionItemList" :label="item.prefix" :key="item.prefix" disabled>
              <span class="question-prefix">{{ item.prefix }}.</span>
              <span v-html="item.content" class="q-item-span-content"></span>
            </el-checkbox>
          </el-checkbox-group>
        </div>
      </div>
      <!-- 判断 -->
      <div v-else-if="qType == 3">
        <div class="q-title" v-html="question.title" style="display: inline;margin-right: 10px" />
        <span style="padding-right: 10px;">(</span>
        <el-radio-group v-model="question.answer">
          <el-radio v-for="item in question.questionItemList" :key="item.prefix" :label="item.prefix " disabled>
            <span v-html="item.content" class="q-item-span-content"></span>
          </el-radio>
        </el-radio-group>
        <span style="padding-left: 10px;">)</span>
      </div>
      <!-- 填空 -->
      <div v-else-if="qType == 4">
        <div class="q-title" v-html="question.title"/>
        <div v-if="question.answerList !== null">
          <el-form-item :label="item.prefix" :key="item.prefix" v-for="item in question.questionItemList"
                        label-width="50px"
                        style="margin-top: 10px;margin-bottom: 10px;">
            <el-input v-model="question.answerList[item.prefix - 1]" disabled/>
          </el-form-item>
        </div>
      </div>
      <!-- 简答、计算、分析 -->
      <div v-else-if="qType == 5 || qType == 7 || qType == 8">
        <div class="q-title" v-html="question.title"/>
        <div>
          <el-input v-model="question.answer" type="textarea" rows="5" ></el-input>
        </div>
      </div>
      <div class="question-answer-show-item" style="margin-top: 15px">
        <span class="question-show-item">结果:</span>
        <el-tag :type="rightTagFormatter(question.right)">
          {{ rightTextFormatter(question.right) }}
        </el-tag>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">总分:</span>
        <span>{{ question.questionScore }}</span>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">得分:</span>
        <span>{{ question.score }}</span>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">难度:</span>
        <el-rate disabled v-model="question.difficult" class="question-show-item"></el-rate>
      </div>
      <br/>
      <div class="question-answer-show-item" style="line-height: 1.8">
        <span class="question-show-item">解析:</span>
        <span v-html="question.analyze" class="q-item-span-content"/>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">正确答案:</span>
        <!-- 选择、多选、简答、语音、计算、分析 -->
        <span v-if="qType == 1 || qType == 2 || qType == 5 || qType == 6 || qType == 7 || qType == 8"
              v-html="question.questionAnswer" class="q-item-span-content"/>
        <!-- 判断 -->
        <span v-if="qType == 3" v-html="trueFalseFormatter(question)" class="q-item-span-content"/>
        <!-- 填空 -->
        <span v-if="qType == 4">{{ question.questionAnswer }}</span>
      </div>
      <span style="color:#ECAB3C;">{{ '批改:' }}</span>
      <el-input-number size="mini" v-model="question.score" :precision="1" :min="0"
                       :max="parseInt(question.questionScore)" @change="updateRight"></el-input-number>
    </div>
    <div v-else>
    </div>
  </div>
</template>
<script>
import { mapState, mapGetters } from 'vuex'
export default {
  name: 'QuestionShow',
  props: {
    question: {
      type: Object,
      default: function () {
        return {}
      }
    },
    answer: {
      type: Array,
      default: function () {
        return {}
      }
    },
    qLoading: {
      type: Boolean,
      default: false
    },
    qType: {
      type: Number,
      default: 0
    }
  },
  methods: {
    updateRight () {
      // 当score变化时,检查它是否等于questionScore
      this.question.right = this.question.score === parseInt(this.question.questionScore)
      const foundAnswer = this.answer.find(answer => answer.itemOrder === this.question.itemOrder)
      if (foundAnswer) {
        foundAnswer.right = this.question.right
      }
    },
    trueFalseFormatter (question) {
      return question.questionItemList.filter(d => d.prefix === question.questionAnswer)[0].content
    },
    rightTagFormatter (status) {
      return this.enumFormat(this.rightTag, status)
    },
    rightTextFormatter (status) {
      return this.enumFormat(this.rightEnum, status)
    }
  },
  computed: {
    ...mapGetters('enumItem', ['enumFormat']),
    ...mapState('enumItem', {
      rightEnum: state => state.exam.question.answer.doRightEnum,
      rightTag: state => state.exam.question.answer.doRightTag
    })
  }
}
</script>
<style scoped>
/deep/ .el-checkbox__input.is-disabled + .el-checkbox__label {
  color: #606266
}
/deep/ .el-checkbox__input.is-disabled.is-checked + .el-checkbox__label {
  color: #606266
}
/deep/ .el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after {
  border-color: #606266
}
/deep/ .el-radio__input.is-disabled + span.el-radio__label {
  color: #606266
}
/deep/ .el-radio__input.is-disabled.is-checked .el-radio__inner::after {
  background-color: #606266;
}
/deep/ .el-radio__input.is-disabled .el-radio__inner, .el-radio__input.is-disabled.is-checked .el-radio__inner {
  border-color: #606266
}
/deep/ .el-input.is-disabled .el-input__inner, textarea:disabled {
  color: #606266
}
/deep/ .el-range-editor.is-disabled input {
  color: #606266
}
</style>
src/views/answer/components/QuestionAnswerShow.vue
@@ -1,12 +1,13 @@
<template>
  <div v-loading="qLoading" style="line-height:1.8">
    <div v-if="qType == 1 || qType == 2 || qType == 3 || qType == 4 || qType == 5 || qType == 6 || qType == 7 || qType == 8">
     <!-- 选择或语音 -->
    <div
      v-if="qType == 1 || qType == 2 || qType == 3 || qType == 4 || qType == 5 || qType == 6 || qType == 7 || qType == 8">
      <!-- 选择或语音 -->
      <div v-if="qType == 1 || qType == 6">
        <div class="q-title" v-html="question.title" />
        <div class="q-title" v-html="question.title"/>
        <div class="q-content">
          <el-radio-group v-model="answer.content">
            <el-radio v-for="item in question.items" :key="item.prefix" :label="item.prefix">
          <el-radio-group v-model="question.answer">
            <el-radio class="custom-radio" v-for="item in question.questionItemList" :key="item.prefix" :label="item.prefix " disabled>
              <span class="question-prefix">{{ item.prefix }}.</span>
              <span v-html="item.content" class="q-item-span-content"></span>
            </el-radio>
@@ -15,10 +16,10 @@
      </div>
      <!-- 多选 -->
      <div v-else-if="qType == 2">
        <div class="q-title" v-html="question.title" />
        <div class="q-title" v-html="question.title"/>
        <div class="q-content">
          <el-checkbox-group v-model="answer.contentArray">
            <el-checkbox v-for="item in question.items" :label="item.prefix" :key="item.prefix">
          <el-checkbox-group v-model="question.answerList">
            <el-checkbox v-for="item in question.questionItemList" :label="item.prefix" :key="item.prefix" disabled>
              <span class="question-prefix">{{ item.prefix }}.</span>
              <span v-html="item.content" class="q-item-span-content"></span>
            </el-checkbox>
@@ -29,8 +30,8 @@
      <div v-else-if="qType == 3">
        <div class="q-title" v-html="question.title" style="display: inline;margin-right: 10px" />
        <span style="padding-right: 10px;">(</span>
        <el-radio-group v-model="answer.content">
          <el-radio v-for="item in question.items" :key="item.prefix" :label="item.prefix">
        <el-radio-group v-model="question.answer">
          <el-radio v-for="item in question.questionItemList" :key="item.prefix" :label="item.prefix " disabled>
            <span v-html="item.content" class="q-item-span-content"></span>
          </el-radio>
        </el-radio-group>
@@ -38,52 +39,54 @@
      </div>
      <!-- 填空 -->
      <div v-else-if="qType == 4">
        <div class="q-title" v-html="question.title" />
        <div v-if="answer.contentArray !== null">
          <el-form-item :label="item.prefix" :key="item.prefix" v-for="item in question.items" label-width="50px"
            style="margin-top: 10px;margin-bottom: 10px;">
            <el-input v-model="answer.contentArray[item.prefix - 1]" />
        <div class="q-title" v-html="question.title"/>
        <div v-if="question.answerList !== null">
          <el-form-item :label="item.prefix" :key="item.prefix" v-for="item in question.questionItemList"
                        label-width="50px"
                        style="margin-top: 10px;margin-bottom: 10px;">
            <el-input v-model="question.answerList[item.prefix - 1]" disabled/>
          </el-form-item>
        </div>
      </div>
      <!-- 简答、计算、分析 -->
      <div v-else-if="qType == 5 || qType == 7 || qType == 8">
        <div class="q-title" v-html="question.title" />
        <div class="q-title" v-html="question.title"/>
        <div>
          <el-input v-model="answer.content" type="textarea" rows="5"></el-input>
          <el-input v-model="question.answer" type="textarea" rows="5" ></el-input>
        </div>
      </div>
      <div class="question-answer-show-item" style="margin-top: 15px">
        <span class="question-show-item">结果:</span>
        <el-tag :type="doRightTagFormatter(answer.doRight)">
          {{ doRightTextFormatter(answer.doRight) }}
        <el-tag :type="rightTagFormatter(question.right)">
          {{ rightTextFormatter(question.right) }}
        </el-tag>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">分数:</span>
        <span class="question-show-item">总分:</span>
        <span>{{ question.questionScore }}</span>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">得分:</span>
        <span>{{ question.score }}</span>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">难度:</span>
        <el-rate disabled v-model="question.difficult" class="question-show-item"></el-rate>
      </div>
      <br />
      <br/>
      <div class="question-answer-show-item" style="line-height: 1.8">
        <span class="question-show-item">解析:</span>
        <span v-html="question.analyze" class="q-item-span-content" />
        <span v-html="question.analyze" class="q-item-span-content"/>
      </div>
      <div class="question-answer-show-item">
        <span class="question-show-item">正确答案:</span>
        <!-- 选择、多选、简答、语音、计算、分析 -->
        <span v-if="qType == 1 || qType == 2 || qType == 5 || qType == 6 || qType == 7 || qType == 8" v-html="question.correct" class="q-item-span-content" />
        <span v-if="qType == 1 || qType == 2 || qType == 5 || qType == 6 || qType == 7 || qType == 8"
              v-html="question.questionAnswer" class="q-item-span-content"/>
        <!-- 判断 -->
        <span v-if="qType == 3" v-html="trueFalseFormatter(question)" class="q-item-span-content" />
        <span v-if="qType == 3" v-html="trueFalseFormatter(question)" class="q-item-span-content"/>
        <!-- 填空 -->
        <span v-if="qType == 4">{{ question.correctArray }}</span>
      </div>
      <div v-if = "answer.doRight == null">
        <span style="color:#ECAB3C;">{{'批改:'}}</span>
        <el-input-number size="mini" v-model="answer.score" :precision="1" :min="0" :max="parseInt(question.score)" ></el-input-number>
        <span v-if="qType == 4">{{ question.questionAnswer }}</span>
      </div>
    </div>
    <div v-else>
@@ -94,6 +97,7 @@
<script>
import { mapState, mapGetters } from 'vuex'
export default {
  name: 'QuestionShow',
  props: {
@@ -104,9 +108,9 @@
      }
    },
    answer: {
      type: Object,
      type: Array,
      default: function () {
        return { id: null, content: '', contentArray: [], doRight: false }
        return {}
      }
    },
    qLoading: {
@@ -119,22 +123,66 @@
    }
  },
  methods: {
    trueFalseFormatter(question) {
      return question.items.filter(d => d.prefix === question.correct)[0].content
    updateRight () {
      // 当score变化时,检查它是否等于questionScore
      this.question.right = this.question.score === parseInt(this.question.questionScore)
      const foundAnswer = this.answer.find(answer => answer.itemOrder === this.question.itemOrder)
      if (foundAnswer) {
        foundAnswer.right = this.question.right
      }
    },
    doRightTagFormatter(status) {
      return this.enumFormat(this.doRightTag, status)
    trueFalseFormatter (question) {
      return question.questionItemList.filter(d => d.prefix === question.questionAnswer)[0].content
    },
    doRightTextFormatter(status) {
      return this.enumFormat(this.doRightEnum, status)
    rightTagFormatter (status) {
      return this.enumFormat(this.rightTag, status)
    },
    rightTextFormatter (status) {
      return this.enumFormat(this.rightEnum, status)
    }
  },
  computed: {
    ...mapGetters('enumItem', ['enumFormat']),
    ...mapState('enumItem', {
      doRightEnum: state => state.exam.question.answer.doRightEnum,
      doRightTag: state => state.exam.question.answer.doRightTag
      rightEnum: state => state.exam.question.answer.doRightEnum,
      rightTag: state => state.exam.question.answer.doRightTag
    })
  }
}
</script>
<style scoped>
/deep/ .el-checkbox__input.is-disabled + .el-checkbox__label {
  color: #606266
}
/deep/ .el-checkbox__input.is-disabled.is-checked + .el-checkbox__label {
  color: #606266
}
/deep/ .el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after {
  border-color: #606266
}
/deep/ .el-radio__input.is-disabled + span.el-radio__label {
  color: #606266
}
/deep/ .el-radio__input.is-disabled.is-checked .el-radio__inner::after {
  background-color: #606266;
}
/deep/ .el-radio__input.is-disabled .el-radio__inner, .el-radio__input.is-disabled.is-checked .el-radio__inner {
  border-color: #606266
}
/deep/ .el-input.is-disabled .el-input__inner, textarea:disabled {
  color: #606266
}
/deep/ .el-range-editor.is-disabled input {
  color: #606266
}
</style>
src/views/answer/detail.vue
@@ -1,322 +1,127 @@
<template>
  <div style="background-color: #FFFFFF; padding-top: 50px;min-height: 900px;">
    <el-row class="do-exam-title" style="background-color: #F5F5DC">
      <el-col :span="24">
                <span :key="item.itemOrder" v-for="item in answer.answerItems">
                    <el-tag :type="questionDoRightTag(item.doRight)" class="do-exam-title-tag"
  <div class="paper-container">
    <div class="paper-card" v-loading="formLoading">
      <el-card style="height: 100vh">
        <el-row style="text-align: left; margin-bottom : 20px; font-size: 20px">语文考试</el-row>
        <el-row>
          <el-col class="info">
            <span class="exam-info">学员姓名:</span>
            <span class="exam-info">{{ form.userName }}</span>
          </el-col>
        </el-row>
        <el-row>
          <el-col class="info">
            <span class="exam-info">交卷时间:</span>
            <span class="exam-info">{{ form.submitTime }}</span>
          </el-col>
        </el-row>
        <el-row>
          <el-col class="info">
            <span class="exam-info">完成耗时:</span>
            <span class="exam-info">{{ formattedDoTime }}</span>
          </el-col>
        </el-row>
        <el-row>
          <el-col class="info">
            <span class="exam-info">得分:</span>
            <span class="exam-info">{{ form.score + ' / ' + form.totalScore }}</span>
          </el-col>
        </el-row>
        <el-divider></el-divider>
        <el-row class="do-exam-title">
          <el-col :span="24">
                <span :key="item.itemOrder" v-for="item in form.navbar">
                    <el-tag :type="questionDoRightTag(item.right)" class="do-exam-title-tag"
                            @click="goAnchor('#question-' + item.itemOrder)">{{ item.itemOrder }}</el-tag>
                </span>
      </el-col>
    </el-row>
    <el-container class="app-item-contain">
      <el-header class="align-center">
        <h1>{{ form.name }}</h1>
        <div>
          <span class="question-title-padding">试卷得分:{{ answer.score }}</span>
          <span class="question-title-padding">试卷耗时:{{ formatSeconds(answer.doTime) }}</span>
        </div>
      </el-header>
      <el-main>
        <el-form :model="form" ref="form" v-loading="formLoading" label-width="100px">
          <el-row :key="index" v-for="(titleItem, index) in form.titleItems">
            <h3>{{ titleItem.name }}</h3>
            <el-card class="exampaper-item-box" v-if="titleItem.questionItems.length !== 0">
              <el-form-item :key="questionItem.itemOrder" :label="questionItem.itemOrder + '.'"
                            v-for="questionItem in titleItem.questionItems" class="exam-question-item"
                            label-width="50px" :id="'question-' + questionItem.itemOrder">
                <QuestionAnswerShow :qType="questionItem.questionType" :question="questionItem"
                                    :answer="answer.answerItems[questionItem.itemOrder - 1]"/>
              </el-form-item>
            </el-card>
          </el-row>
        </el-form>
      </el-main>
    </el-container>
          </el-col>
        </el-row>
      </el-card>
    </div>
    <div class="paper-form">
      <el-form :model="form" ref="form" v-loading="formLoading" label-width="100px">
        <el-row :key="index" v-for="(titleItem, index) in form.titleItems">
          <h3>{{ titleItem.title }}</h3>
          <el-card class="exampaper-item-box" v-if="titleItem.questionList.length !== 0">
            <el-form-item :key="questionItem.itemOrder" :label="questionItem.itemOrder + '.'"
                          v-for="questionItem in titleItem.questionList" class="exam-question-item"
                          label-width="50px" :id="'question-' + questionItem.itemOrder">
              <MarkPaperShow :qType="questionItem.questionType" :question="questionItem" :answer="form.navbar"/>
            </el-form-item>
          </el-card>
        </el-row>
      </el-form>
    </div>
  </div>
</template>
<script>
import { mapState, mapGetters } from 'vuex'
import QuestionAnswerShow from './components/QuestionAnswerShow'
import examPaperAnswerApi from '@/api/examPaperAnswer'
import MarkPaperShow from '@/views/answer/components/QuestionAnswerShow'
import { mapGetters, mapState } from 'vuex'
export default {
  components: { QuestionAnswerShow },
  data () {
    return {
      form: {},
      formLoading: false,
      answer: {
        id: null,
        score: 0,
        doTime: 0,
        answerItems: [],
        doRight: false
      }
    }
  },
  created () {
  name: 'MarkPaperDetail',
  components: { MarkPaperShow },
  mounted () {
    let id = this.$route.query.id
    let _this = this
    if (id && parseInt(id) !== 0) {
      _this.formLoading = true
      this.formLoading = true
      examPaperAnswerApi.read(id).then(re => {
        re = {
          'code': 1, 'message': '成功', 'data': {
            'paper': {
              'id': 30,
              'level': 1,
              'subjectId': 4,
              'paperType': 7,
              'name': '这是一个测试试卷',
              'suggestTime': 12,
              'limitDateTime': null,
              'titleItems': [{
                'name': '单选题',
                'questionItems': [{
                  'id': 25,
                  'questionType': 1,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列正确的是',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '红楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '白楼梦',
                    'score': null,
                    'itemUuid': null
                  }, { 'prefix': 'C', 'content': '青楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'D',
                    'content': '绿楼梦',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': null,
                  'correct': 'A',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 1,
                  'knowledgeIdList': [8, 9]
                }, {
                  'id': 30,
                  'questionType': 1,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列正确的是',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '红楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '白楼梦',
                    'score': null,
                    'itemUuid': null
                  }, { 'prefix': 'C', 'content': '青楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'D',
                    'content': '绿楼梦',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': null,
                  'correct': 'A',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 2,
                  'knowledgeIdList': [8, 9]
                }]
              }, {
                'name': '多选题',
                'questionItems': [{
                  'id': 26,
                  'questionType': 2,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列正确的是',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '红楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '白楼梦',
                    'score': null,
                    'itemUuid': null
                  }, { 'prefix': 'C', 'content': '青楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'D',
                    'content': '绿楼梦',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': ['A', 'C'],
                  'correct': 'A,C',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 3,
                  'knowledgeIdList': [8, 9]
                }, {
                  'id': 31,
                  'questionType': 2,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列正确的是',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '红楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '白楼梦',
                    'score': null,
                    'itemUuid': null
                  }, { 'prefix': 'C', 'content': '青楼梦', 'score': null, 'itemUuid': null }, {
                    'prefix': 'D',
                    'content': '绿楼梦',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': ['A', 'C'],
                  'correct': 'A,C',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 4,
                  'knowledgeIdList': [8, 9]
                }]
              }, {
                'name': '判断题',
                'questionItems': [{
                  'id': 27,
                  'questionType': 3,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列说明正确吗',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '正确', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '错误',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': null,
                  'correct': 'A',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 5,
                  'knowledgeIdList': [8, 9]
                }, {
                  'id': 32,
                  'questionType': 3,
                  'subjectId': 4,
                  'title': '中华四大名著都有哪些,下列说明正确吗',
                  'gradeLevel': 1,
                  'items': [{ 'prefix': 'A', 'content': '正确', 'score': null, 'itemUuid': null }, {
                    'prefix': 'B',
                    'content': '错误',
                    'score': null,
                    'itemUuid': null
                  }],
                  'analyze': '题目比较简单,自行分析',
                  'correctArray': null,
                  'correct': 'A',
                  'score': '2.5',
                  'difficult': 3,
                  'itemOrder': 6,
                  'knowledgeIdList': [8, 9]
                }]
              }],
              'score': '15',
              'classes': null
            },
            'answer': {
              'id': 9,
              'doTime': 26,
              'score': '100',
              'createUser': null,
              'answerItems': [{
                'id': 25,
                'questionId': 25,
                'doRight': true,
                'content': 'A',
                'itemOrder': 1,
                'contentArray': null,
                'score': '2.5',
                'questionScore': '2.5'
              }, {
                'id': 26,
                'questionId': 30,
                'doRight': false,
                'content': 'C',
                'itemOrder': 2,
                'contentArray': null,
                'score': '0',
                'questionScore': '2.5'
              }, {
                'id': 27,
                'questionId': 26,
                'doRight': false,
                'content': '',
                'itemOrder': 3,
                'contentArray': [''],
                'score': '0',
                'questionScore': '2.5'
              }, {
                'id': 28,
                'questionId': 31,
                'doRight': false,
                'content': 'C,D',
                'itemOrder': 4,
                'contentArray': ['C', 'D'],
                'score': '0',
                'questionScore': '2.5'
              }, {
                'id': 29,
                'questionId': 27,
                'doRight': true,
                'content': 'A',
                'itemOrder': 5,
                'contentArray': null,
                'score': '2.5',
                'questionScore': '2.5'
              }, {
                'id': 30,
                'questionId': 32,
                'doRight': true,
                'content': 'A',
                'itemOrder': 6,
                'contentArray': null,
                'score': '2.5',
                'questionScore': '2.5'
              }],
              'doTimeStr': '26秒'
            }
          }
        }
        _this.form = re.data.paper
        _this.answer = re.data.answer
        _this.formLoading = false
        this.formLoading = true
        this.form = re.data
        console.log('this.form', this.form);
        this.formLoading = false
      })
    }
  },
  data () {
    return {
      paperQuestionList: [],
      form: {},
      formLoading: false,
      userId: null,
      userName: '张三',
      questionLoading: false
    }
  },
  methods: {
    formatSeconds (theTime) {
      let theTime1 = 0
      let theTime2 = 0
      if (theTime > 60) {
        theTime1 = parseInt(theTime / 60)
        theTime = parseInt(theTime % 60)
        if (theTime1 > 60) {
          theTime2 = parseInt(theTime1 / 60)
          theTime1 = parseInt(theTime1 % 60)
        }
      }
      let result = '' + parseInt(theTime) + '秒'
      if (theTime1 > 0) {
        result = '' + parseInt(theTime1) + '分' + result
      }
      if (theTime2 > 0) {
        result = '' + parseInt(theTime2) + '小时' + result
      }
      return result
    open () {
      this.$confirm('确认是否提交成绩批改?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        submitMark(this.form).then(re => {
          if (re.data.code === 1) {
            console.log('1111111')
            this.$message.success('提交成功')
            this.$router.back()
          } else {
            this.$message.error(re.message)
          }
        })
      })
    },
    goAnchor (selector) {
      this.$el.querySelector(selector).scrollIntoView({ behavior: 'instant', block: 'center', inline: 'nearest' })
    },
    questionDoRightTag (status) {
      return this.enumFormat(this.doRightTag, status)
    },
    goAnchor (selector) {
      this.$el.querySelector(selector).scrollIntoView({ behavior: 'instant', block: 'center', inline: 'nearest' })
    getStudentPaper () {
      getStudentExam(this.examInfo.examId, this.userId).then(res => {
        this.examInfo = res.data.data
      })
    }
  },
  computed: {
    formattedDoTime () {
      const totalSeconds = this.form.doTime
      const minutes = Math.floor(totalSeconds / 60)
      const seconds = totalSeconds % 60
      return `${minutes}分${seconds < 10 ? '0' + seconds : seconds}秒`
    },
    ...mapGetters('enumItem', ['enumFormat']),
    ...mapState('enumItem', {
      doRightTag: state => state.exam.question.answer.doRightTag
@@ -325,21 +130,32 @@
}
</script>
<style lang="scss" scoped>
.align-center {
  text-align: center
<style scoped>
.paper-container {
  display: flex;
  flex-direction: row;
  height: 100%;
  padding: 20px;
  min-height: 100%;
}
.exam-question-item {
  padding: 10px;
  .el-form-item__label {
    font-size: 15px !important;
  }
.paper-card {
  position: fixed;
  width: 270px;
}
.question-title-padding {
  padding-left: 25px;
  padding-right: 25px;
.paper-form {
  flex: 1; /* 占据剩余空间 */
  margin-left: 300px;
}
.info {
  display: flex;
  flex-direction: row;
  justify-content: left;
  font-size: 14px;
  margin-top: 10px;
}
</style>
src/views/answer/info.vue
@@ -103,7 +103,7 @@
        var url = window.URL.createObjectURL(x.response);
        var a = document.createElement("a");
        a.href = url;
        a.download = that.tableData[0].paperName + '.xlsx';
        a.download = that.tableData[0].examName + '.xlsx';
        a.click();
      };
      x.send();