Commit 45504a9526025fb3edd41d23e3be926d74d826ba
1 parent
aeac66d4
即时测页面,以及小题修改答案
Showing
6 changed files
with
326 additions
and
176 deletions
src/components/setAnswer.vue
1 | <template> | 1 | <template> |
2 | - <div class="el-dialog-wrapper" v-show="diaVisible" width="400" center @click.self="cancel"> | 2 | + <div |
3 | + class="el-dialog-wrapper" | ||
4 | + v-show="diaVisible" | ||
5 | + width="400" | ||
6 | + center | ||
7 | + @click.self="cancel" | ||
8 | + > | ||
3 | <div class="el-dialog-content"> | 9 | <div class="el-dialog-content"> |
4 | <p class="title"> | 10 | <p class="title"> |
5 | - <!-- 设置答案 <i class="fa fa-exchange" @click="editType = !editType"></i> --> | ||
6 | - 设置答案 | 11 | + 设置答案 <i class="fa fa-exchange" @click="editType = !editType"></i> |
12 | + <!-- 设置答案 --> | ||
7 | <i class="el-icon-close" @click="cancel"></i> | 13 | <i class="el-icon-close" @click="cancel"></i> |
8 | </p> | 14 | </p> |
9 | - <div v-show="editType"> | 15 | + <div v-if="editType"> |
10 | <div v-for="(item, index) in FormQuestionList" :key="index"> | 16 | <div v-for="(item, index) in FormQuestionList" :key="index"> |
11 | <template v-for="(subQuestions, indexs) in item.subQuestions"> | 17 | <template v-for="(subQuestions, indexs) in item.subQuestions"> |
12 | <div | 18 | <div |
@@ -61,97 +67,90 @@ | @@ -61,97 +67,90 @@ | ||
61 | </template> | 67 | </template> |
62 | </div> | 68 | </div> |
63 | </div> | 69 | </div> |
64 | - <!-- <div v-show="!editType"> | 70 | + <div v-else> |
65 | <p class="dia-tips"> | 71 | <p class="dia-tips"> |
66 | - 请点击选项按钮设置答案,多选题题目之间用“,”隔开,若添加5道题:“AC,AD,BD,AC,CD” | ||
67 | - </p> | 72 | + 请点击选项按钮设置答案,多选题题目之间用“,”隔开,若添加5道题:“AC,AD,BD,AC,CD” |
73 | + </p> | ||
68 | <div class="dia-question-box"> | 74 | <div class="dia-question-box"> |
69 | <div v-for="(item, index) in FormQuestionList2" :key="index"> | 75 | <div v-for="(item, index) in FormQuestionList2" :key="index"> |
70 | - <template v-for="(items, indexs) in item.subQuestions"> | ||
71 | - <div class="set-questions" :key="indexs"> | ||
72 | - <div class="qs-num"> | ||
73 | - <p>{{ items.name }}</p> | ||
74 | - <p>共{{ items.list.length }}题</p> | ||
75 | - </div> | ||
76 | - <div class="qs-options"> | ||
77 | - <p class="ipt"> | ||
78 | - <el-input | ||
79 | - v-model="items.answerList" | ||
80 | - @keydown.native="keydownAnswer($event)" | ||
81 | - ></el-input> | ||
82 | - </p> | ||
83 | - <p class="answer-box"> | ||
84 | - <template v-if="items.list[0].questionType == 4"> | ||
85 | - <span | ||
86 | - class="answer-s active" | ||
87 | - @click=" | ||
88 | - items.answerList.length < items.list.length | ||
89 | - ? (items.answerList += '✓') | ||
90 | - : '' | ||
91 | - " | ||
92 | - >✓</span | ||
93 | - > | ||
94 | - <span | ||
95 | - class="answer-s active" | ||
96 | - @click=" | ||
97 | - items.answerList.length < items.list.length | ||
98 | - ? (items.answerList += '✗') | ||
99 | - : '' | ||
100 | - " | ||
101 | - >✗</span | ||
102 | - > | ||
103 | - </template> | ||
104 | - <template v-if="items.list[0].questionType == 3"> | ||
105 | - <span | ||
106 | - class="answer-s active" | ||
107 | - v-for="option in items.list[0].answerOptions" | ||
108 | - :key="option" | ||
109 | - @click="setAnswer(items,option)" | ||
110 | - >{{ option }}</span | ||
111 | - > | ||
112 | - <span | ||
113 | - class="answer-s active" | ||
114 | - @click=" | ||
115 | - items.answerList.split(',').length < items.list.length | ||
116 | - ? (items.answerList += ',') | ||
117 | - : '' | ||
118 | - " | ||
119 | - >,</span | ||
120 | - > | ||
121 | - </template> | ||
122 | - <template | ||
123 | - v-if="items.list[0].questionType == 2" | ||
124 | - class="answer-box" | 76 | + <div class="set-questions"> |
77 | + <div class="qs-num"> | ||
78 | + <p class="txt">{{ item.name }}</p> | ||
79 | + <p class="num">共{{ item.list.length }}题</p> | ||
80 | + </div> | ||
81 | + <div class="qs-options"> | ||
82 | + <p class="ipt"> | ||
83 | + <el-input | ||
84 | + v-model="item.answerList" | ||
85 | + @keydown.native="keydownAnswer($event)" | ||
86 | + ></el-input> | ||
87 | + </p> | ||
88 | + <p class="answer-box"> | ||
89 | + <template v-if="item.list[0].questionType == 4"> | ||
90 | + <span | ||
91 | + class="answer-s active" | ||
92 | + @click=" | ||
93 | + item.answerList.length < item.list.length | ||
94 | + ? (item.answerList += '✓') | ||
95 | + : '' | ||
96 | + " | ||
97 | + >✓</span | ||
98 | + > | ||
99 | + <span | ||
100 | + class="answer-s active" | ||
101 | + @click=" | ||
102 | + item.answerList.length < item.list.length | ||
103 | + ? (item.answerList += '✗') | ||
104 | + : '' | ||
105 | + " | ||
106 | + >✗</span | ||
125 | > | 107 | > |
126 | - <span | ||
127 | - class="answer-s active" | ||
128 | - v-for="option in items.list[0].answerOptions" | ||
129 | - :key="option" | ||
130 | - @click=" | ||
131 | - items.answerList.length < items.list.length | ||
132 | - ? (items.answerList += option) | ||
133 | - : '' | ||
134 | - " | ||
135 | - >{{ option }}</span | ||
136 | - > | ||
137 | - </template> | 108 | + </template> |
109 | + <template v-if="item.list[0].questionType == 3"> | ||
138 | <span | 110 | <span |
139 | - class="answer-s delButton" | ||
140 | - @click="items.answerList = items.answerList.slice(0, -1)" | ||
141 | - >x</span | 111 | + class="answer-s active" |
112 | + v-for="option in item.list[0].answerOptions" | ||
113 | + :key="option" | ||
114 | + @click="setAnswer(item, option)" | ||
115 | + >{{ option }}</span | ||
142 | > | 116 | > |
143 | <span | 117 | <span |
144 | - class="answer-s ac" | ||
145 | - @click="items.answerList = ''" | ||
146 | - >AC</span | 118 | + class="answer-s active" |
119 | + @click=" | ||
120 | + item.answerList.split(',').length < item.list.length | ||
121 | + ? (item.answerList += ',') | ||
122 | + : '' | ||
123 | + " | ||
124 | + >,</span | ||
147 | > | 125 | > |
148 | - </p> | ||
149 | - </div> | 126 | + </template> |
127 | + <template | ||
128 | + v-if="item.list[0].questionType == 2" | ||
129 | + class="answer-box" | ||
130 | + > | ||
131 | + <span | ||
132 | + class="answer-s active" | ||
133 | + v-for="option in item.list[0].answerOptions" | ||
134 | + :key="option" | ||
135 | + @click=" | ||
136 | + item.answerList.length < item.list.length | ||
137 | + ? (item.answerList += option) | ||
138 | + : '' | ||
139 | + " | ||
140 | + >{{ option }}</span | ||
141 | + > | ||
142 | + </template> | ||
143 | + <span | ||
144 | + class="answer-s delButton" | ||
145 | + @click="item.answerList = item.answerList.slice(0, -1)" | ||
146 | + >x</span | ||
147 | + > | ||
148 | + </p> | ||
150 | </div> | 149 | </div> |
151 | - </template> | 150 | + </div> |
152 | </div> | 151 | </div> |
153 | </div> | 152 | </div> |
154 | - </div> --> | 153 | + </div> |
155 | <div class="footer-box"> | 154 | <div class="footer-box"> |
156 | <el-button class="dia-btn" type="primary" @click="saveAnswer" | 155 | <el-button class="dia-btn" type="primary" @click="saveAnswer" |
157 | >确 定</el-button | 156 | >确 定</el-button |
@@ -165,7 +164,7 @@ | @@ -165,7 +164,7 @@ | ||
165 | </template> | 164 | </template> |
166 | 165 | ||
167 | <script> | 166 | <script> |
168 | -import { deepClone } from "utils"; | 167 | +import { deepClone, checkAnswer } from "utils"; |
169 | export default { | 168 | export default { |
170 | name: "SetAnswer", | 169 | name: "SetAnswer", |
171 | props: { | 170 | props: { |
@@ -177,42 +176,55 @@ export default { | @@ -177,42 +176,55 @@ export default { | ||
177 | return { | 176 | return { |
178 | editType: true, //修改答案模式 | 177 | editType: true, //修改答案模式 |
179 | FormQuestionList: [], | 178 | FormQuestionList: [], |
179 | + FormQuestionList2: [], | ||
180 | }; | 180 | }; |
181 | }, | 181 | }, |
182 | watch: { | 182 | watch: { |
183 | questionList: { | 183 | questionList: { |
184 | handler: function () { | 184 | handler: function () { |
185 | this.FormQuestionList = deepClone(this.questionList); | 185 | this.FormQuestionList = deepClone(this.questionList); |
186 | + this.FormQuestionList2 = []; | ||
186 | console.log(this.questionList); | 187 | console.log(this.questionList); |
187 | - //组合每道大题中的相同题目 | ||
188 | - // let questionList = deepClone(item.questionList); | ||
189 | - // for (let i = 0; i < questionList.length; i++) { | ||
190 | - // let jsons = {}; | ||
191 | - // let answerOptions = []; | ||
192 | - // questionList[i].subQuestions.map((items) => { | ||
193 | - // let txt = this.setSubPro(items.questionType); | ||
194 | - // if (jsons[txt]) { | ||
195 | - // jsons[txt].push(items); | ||
196 | - // } else { | ||
197 | - // jsons[txt] = [items]; | ||
198 | - // } | ||
199 | - // if (items.questionType == 2 || items.questionType == 3) { | ||
200 | - // if (items.answerOptions.length > answerOptions.length) { | ||
201 | - // answerOptions = items.answerOptions; | ||
202 | - // } | ||
203 | - // jsons[txt][0].answerOptions = answerOptions; | ||
204 | - // } | ||
205 | - // }); | ||
206 | - // this.FormQuestionList2[i].subQuestions = Object.keys(jsons).map( | ||
207 | - // (item) => { | ||
208 | - // return { | ||
209 | - // name: item, | ||
210 | - // list: jsons[item], | ||
211 | - // answerList: "", | ||
212 | - // }; | ||
213 | - // } | ||
214 | - // ); | ||
215 | - // } | 188 | + // 组合每道大题中的相同题目 |
189 | + let questionList = deepClone(this.questionList); | ||
190 | + let jsons = {}; | ||
191 | + let answerOptions = []; | ||
192 | + for (let i = 0; i < questionList.length; i++) { | ||
193 | + questionList[i].subQuestions.map((items) => { | ||
194 | + let txt = this.setSubPro(items.questionType); | ||
195 | + if (jsons[txt]) { | ||
196 | + jsons[txt].push(items); | ||
197 | + } else { | ||
198 | + jsons[txt] = [items]; | ||
199 | + } | ||
200 | + if (items.questionType == 2 || items.questionType == 3) { | ||
201 | + if (items.answerOptions.length > answerOptions.length) { | ||
202 | + answerOptions = items.answerOptions; | ||
203 | + } | ||
204 | + jsons[txt][0].answerOptions = answerOptions; | ||
205 | + } | ||
206 | + }); | ||
207 | + console.log(jsons); | ||
208 | + } | ||
209 | + this.FormQuestionList2 = Object.keys(jsons).map((item) => { | ||
210 | + let answerList = ""; | ||
211 | + jsons[item].map((items, index) => { | ||
212 | + if (items.questionType == 2) { | ||
213 | + answerList += items.correctAnswer; | ||
214 | + } else if (items.questionType == 3) { | ||
215 | + answerList += | ||
216 | + items.correctAnswer + | ||
217 | + (jsons[item].length - 1 != index ? "," : ""); | ||
218 | + } else if (items.questionType == 4) { | ||
219 | + answerList += items.correctAnswer == 1 ? "✓" : "✗"; | ||
220 | + } | ||
221 | + }); | ||
222 | + return { | ||
223 | + name: item, | ||
224 | + list: jsons[item], | ||
225 | + answerList: answerList, | ||
226 | + }; | ||
227 | + }); | ||
216 | }, | 228 | }, |
217 | deep: true, | 229 | deep: true, |
218 | }, | 230 | }, |
@@ -282,6 +294,37 @@ export default { | @@ -282,6 +294,37 @@ export default { | ||
282 | } | 294 | } |
283 | }, | 295 | }, |
284 | async saveAnswer() { | 296 | async saveAnswer() { |
297 | + let questionList = [], | ||
298 | + questionList2 = []; | ||
299 | + if (this.editType) { | ||
300 | + questionList = [...this.FormQuestionList]; | ||
301 | + } else { | ||
302 | + this.FormQuestionList2.map((item) => { | ||
303 | + item.list.map((items, index) => { | ||
304 | + if (items.questionType == 2 ) { | ||
305 | + items.correctAnswer = item.answerList.split("")[index]; | ||
306 | + } else if (items.questionType == 3) { | ||
307 | + items.correctAnswer = item.answerList.split(",")[index]; | ||
308 | + }else if (items.questionType == 4) { | ||
309 | + items.correctAnswer = item.answerList[index] == "✓" ? 1 : 2; | ||
310 | + } | ||
311 | + questionList2.push(items); | ||
312 | + }); | ||
313 | + }); | ||
314 | + questionList = this.FormQuestionList.map((item) => { | ||
315 | + let subQuestions = item.subQuestions.map((items) => { | ||
316 | + items.correctAnswer = questionList2.find((question) => { | ||
317 | + return question.questionIndex == items.questionIndex; | ||
318 | + })?.correctAnswer; | ||
319 | + return items; | ||
320 | + }); | ||
321 | + return { | ||
322 | + ...item, | ||
323 | + subQuestions: [...subQuestions], | ||
324 | + }; | ||
325 | + }); | ||
326 | + } | ||
327 | + console.log(questionList); | ||
285 | const { data, status, message } = await this.$request.modifyPaper({ | 328 | const { data, status, message } = await this.$request.modifyPaper({ |
286 | paperId: this.paperId, | 329 | paperId: this.paperId, |
287 | questionList: questionList, | 330 | questionList: questionList, |
@@ -315,22 +358,29 @@ export default { | @@ -315,22 +358,29 @@ export default { | ||
315 | z-index: 2022; | 358 | z-index: 2022; |
316 | .el-dialog-content { | 359 | .el-dialog-content { |
317 | width: 600px; | 360 | width: 600px; |
318 | - background:#fff; | 361 | + background: #fff; |
319 | border-radius: 10px; | 362 | border-radius: 10px; |
320 | - padding:16px 20px 20px; | 363 | + padding: 16px 20px 20px; |
321 | } | 364 | } |
322 | - .title{ | 365 | + .title { |
323 | font-size: 18px; | 366 | font-size: 18px; |
324 | position: relative; | 367 | position: relative; |
325 | - margin-bottom:20px; | ||
326 | - .el-icon-close{ | 368 | + margin-bottom: 20px; |
369 | + .el-icon-close { | ||
327 | position: absolute; | 370 | position: absolute; |
328 | - top:0; | ||
329 | - right:12px; | ||
330 | - padding:2px; | 371 | + top: 0; |
372 | + right: 12px; | ||
373 | + padding: 2px; | ||
331 | font-size: 16px; | 374 | font-size: 16px; |
332 | cursor: pointer; | 375 | cursor: pointer; |
333 | - &:hover{ | 376 | + &:hover { |
377 | + color: #667ffa; | ||
378 | + } | ||
379 | + } | ||
380 | + .fa-exchange { | ||
381 | + color: #999; | ||
382 | + cursor: pointer; | ||
383 | + &:hover { | ||
334 | color: #667ffa; | 384 | color: #667ffa; |
335 | } | 385 | } |
336 | } | 386 | } |
@@ -338,7 +388,7 @@ export default { | @@ -338,7 +388,7 @@ export default { | ||
338 | } | 388 | } |
339 | .footer-box { | 389 | .footer-box { |
340 | text-align: center; | 390 | text-align: center; |
341 | - padding-top:20px; | 391 | + padding-top: 20px; |
342 | } | 392 | } |
343 | .sub-questions { | 393 | .sub-questions { |
344 | width: 100%; | 394 | width: 100%; |
@@ -391,4 +441,48 @@ export default { | @@ -391,4 +441,48 @@ export default { | ||
391 | } | 441 | } |
392 | } | 442 | } |
393 | } | 443 | } |
444 | +.dia-tips { | ||
445 | + line-height: 18px; | ||
446 | + padding-bottom: 10px; | ||
447 | +} | ||
448 | +.set-questions { | ||
449 | + display: flex; | ||
450 | + padding-right: 20px; | ||
451 | + margin-bottom: 20px; | ||
452 | + .qs-num { | ||
453 | + width: 80px; | ||
454 | + padding-top: 6px; | ||
455 | + .txt { | ||
456 | + font-size: 16px; | ||
457 | + line-height: 18px; | ||
458 | + margin-bottom: 6px; | ||
459 | + } | ||
460 | + } | ||
461 | + .qs-options { | ||
462 | + flex: 1; | ||
463 | + .ipt { | ||
464 | + margin-bottom: 5px; | ||
465 | + } | ||
466 | + .answer-box { | ||
467 | + .answer-s { | ||
468 | + cursor: pointer; | ||
469 | + user-select: none; | ||
470 | + &:first-of-type { | ||
471 | + margin-left: 0; | ||
472 | + } | ||
473 | + } | ||
474 | + } | ||
475 | + } | ||
476 | + .delButton { | ||
477 | + border-color: #ff6868; | ||
478 | + background: #ff6868 url("../assets/images/arrow.png") no-repeat center; | ||
479 | + background-size: 19px; | ||
480 | + color: transparent; | ||
481 | + } | ||
482 | + .ac { | ||
483 | + border-color: #ff6868; | ||
484 | + background: #ff6868; | ||
485 | + color: #fff; | ||
486 | + } | ||
487 | +} | ||
394 | </style> | 488 | </style> |
395 | \ No newline at end of file | 489 | \ No newline at end of file |
src/views/ask/index.vue
@@ -27,7 +27,7 @@ | @@ -27,7 +27,7 @@ | ||
27 | multiple | 27 | multiple |
28 | collapse-tags | 28 | collapse-tags |
29 | v-model="query.subjectId" | 29 | v-model="query.subjectId" |
30 | - placeholder="" | 30 | + placeholder="选择科目" |
31 | @change="_QueryData" | 31 | @change="_QueryData" |
32 | > | 32 | > |
33 | <el-option | 33 | <el-option |
@@ -42,7 +42,7 @@ | @@ -42,7 +42,7 @@ | ||
42 | v-else | 42 | v-else |
43 | class="sel" | 43 | class="sel" |
44 | v-model="query.subjectId" | 44 | v-model="query.subjectId" |
45 | - placeholder="" | 45 | + placeholder="选择科目" |
46 | @change="_QueryData" | 46 | @change="_QueryData" |
47 | > | 47 | > |
48 | <el-option | 48 | <el-option |
@@ -146,7 +146,7 @@ | @@ -146,7 +146,7 @@ | ||
146 | ><template slot-scope="scoped">{{scoped.row.allzheng}}%</template></el-table-column> | 146 | ><template slot-scope="scoped">{{scoped.row.allzheng}}%</template></el-table-column> |
147 | <el-table-column label="操作" align="center"> | 147 | <el-table-column label="操作" align="center"> |
148 | <template slot-scope="scoped"> | 148 | <template slot-scope="scoped"> |
149 | - <el-tooltip effect="dark" content="详情" placement="left"> | 149 | + <el-tooltip effect="dark" content="详情" placement="top"> |
150 | <el-button | 150 | <el-button |
151 | type="primary" | 151 | type="primary" |
152 | circle | 152 | circle |
@@ -155,7 +155,7 @@ | @@ -155,7 +155,7 @@ | ||
155 | @click="linkTo(scoped.row)" | 155 | @click="linkTo(scoped.row)" |
156 | ></el-button> | 156 | ></el-button> |
157 | </el-tooltip> | 157 | </el-tooltip> |
158 | - <el-tooltip effect="dark" content="修改答案" placement="right"> | 158 | + <el-tooltip effect="dark" content="修改答案" placement="top"> |
159 | <el-button | 159 | <el-button |
160 | type="primary" | 160 | type="primary" |
161 | circle | 161 | circle |
@@ -345,7 +345,7 @@ export default { | @@ -345,7 +345,7 @@ export default { | ||
345 | correctAnswer: "A", | 345 | correctAnswer: "A", |
346 | }, | 346 | }, |
347 | { | 347 | { |
348 | - questionIndex: 2, | 348 | + questionIndex: 3, |
349 | questionType: 3, | 349 | questionType: 3, |
350 | score: 1, | 350 | score: 1, |
351 | partScore: 0, | 351 | partScore: 0, |
@@ -354,7 +354,7 @@ export default { | @@ -354,7 +354,7 @@ export default { | ||
354 | correctAnswer: "AB", | 354 | correctAnswer: "AB", |
355 | }, | 355 | }, |
356 | { | 356 | { |
357 | - questionIndex: 2, | 357 | + questionIndex: 4, |
358 | questionType: 3, | 358 | questionType: 3, |
359 | score: 1, | 359 | score: 1, |
360 | partScore: 0, | 360 | partScore: 0, |
@@ -363,7 +363,58 @@ export default { | @@ -363,7 +363,58 @@ export default { | ||
363 | correctAnswer: "AB", | 363 | correctAnswer: "AB", |
364 | }, | 364 | }, |
365 | { | 365 | { |
366 | - questionIndex: 3, | 366 | + questionIndex: 5, |
367 | + questionType: 4, | ||
368 | + score: 1, | ||
369 | + partScore: 0, | ||
370 | + selectNum: 0, | ||
371 | + answerOptions: [], | ||
372 | + correctAnswer: "1", | ||
373 | + }, | ||
374 | + ], | ||
375 | + }, | ||
376 | + { | ||
377 | + questionTitle: "f", | ||
378 | + score: 1, | ||
379 | + subQuestions: [ | ||
380 | + { | ||
381 | + questionIndex: 6, | ||
382 | + questionType: 2, | ||
383 | + score: 1, | ||
384 | + partScore: 0, | ||
385 | + selectNum: 4, | ||
386 | + answerOptions: ["A", "B", "C", "D"], | ||
387 | + correctAnswer: "B", | ||
388 | + }, | ||
389 | + { | ||
390 | + questionIndex: 7, | ||
391 | + questionType: 2, | ||
392 | + score: 1, | ||
393 | + partScore: 0, | ||
394 | + selectNum: 4, | ||
395 | + answerOptions: ["A", "B", "C", "D", "E", "F"], | ||
396 | + correctAnswer: "A", | ||
397 | + }, | ||
398 | + { | ||
399 | + questionIndex: 8, | ||
400 | + questionType: 3, | ||
401 | + score: 1, | ||
402 | + partScore: 0, | ||
403 | + selectNum: 4, | ||
404 | + answerOptions: ["A", "B", "C", "D", "E", "F"], | ||
405 | + correctAnswer: "AB", | ||
406 | + }, | ||
407 | + { | ||
408 | + questionIndex: 9, | ||
409 | + questionType: 3, | ||
410 | + score: 1, | ||
411 | + partScore: 0, | ||
412 | + selectNum: 4, | ||
413 | + answerOptions: ["A", "B", "C", "D", "E", "F"], | ||
414 | + correctAnswer: "AB", | ||
415 | + }, | ||
416 | + { | ||
417 | + questionIndex: 10, | ||
367 | questionType: 4, | 418 | questionType: 4, |
368 | score: 1, | 419 | score: 1, |
369 | partScore: 0, | 420 | partScore: 0, |
@@ -439,10 +490,7 @@ export default { | @@ -439,10 +490,7 @@ export default { | ||
439 | }; | 490 | }; |
440 | }, | 491 | }, |
441 | async created() { | 492 | async created() { |
442 | - this.role = this.$store.getters.info.permissions[0]?.role||""; | ||
443 | - if (this.role == "ROLE_BANZHUREN") { | ||
444 | - this.query.subjectId = []; | ||
445 | - } | 493 | + this.role = this.$store.getters.info.permissions.find(item=>item.roleName == this.$store.getters.info.showRoleName)?.role; |
446 | await this._QueryClassList(); | 494 | await this._QueryClassList(); |
447 | await this._QuerySubjectList(); | 495 | await this._QuerySubjectList(); |
448 | // await this.setDate(1); | 496 | // await this.setDate(1); |
@@ -552,7 +600,7 @@ export default { | @@ -552,7 +600,7 @@ export default { | ||
552 | this.classList = data.list.map((item) => { | 600 | this.classList = data.list.map((item) => { |
553 | return { | 601 | return { |
554 | value: item.classId, | 602 | value: item.classId, |
555 | - label: item.clazzName, | 603 | + label: item.className, |
556 | }; | 604 | }; |
557 | }); | 605 | }); |
558 | this.query.classId = this.classList[0]?.value; | 606 | this.query.classId = this.classList[0]?.value; |
@@ -565,10 +613,10 @@ export default { | @@ -565,10 +613,10 @@ export default { | ||
565 | {classId: this.query.classId,} | 613 | {classId: this.query.classId,} |
566 | ); | 614 | ); |
567 | if (status === 0) { | 615 | if (status === 0) { |
568 | - this.subjectList = data.list?.map((item) => { | 616 | + this.subjectList = data.subjectNames?.map((item) => { |
569 | return { | 617 | return { |
570 | - value: item.subjectId, | ||
571 | - label: item.subjectName, | 618 | + value: item, |
619 | + label: item, | ||
572 | }; | 620 | }; |
573 | })||[]; | 621 | })||[]; |
574 | if (this.role == "ROLE_BANZHUREN") { | 622 | if (this.role == "ROLE_BANZHUREN") { |
@@ -576,8 +624,10 @@ export default { | @@ -576,8 +624,10 @@ export default { | ||
576 | value: "", | 624 | value: "", |
577 | label: "全部", | 625 | label: "全部", |
578 | }); | 626 | }); |
627 | + this.query.subjectId = [this.subjectList[0]?.value]; | ||
628 | + }else{ | ||
629 | + this.query.subjectId = this.subjectList[0]?.value; | ||
579 | } | 630 | } |
580 | - this.query.subjectId = this.subjectList[0]?.value; | ||
581 | } else { | 631 | } else { |
582 | this.$message.error(info); | 632 | this.$message.error(info); |
583 | } | 633 | } |
src/views/index/mainIndex.vue
@@ -100,7 +100,8 @@ | @@ -100,7 +100,8 @@ | ||
100 | </div> | 100 | </div> |
101 | <div class="text" v-else-if="item.path == '/portrait'"> | 101 | <div class="text" v-else-if="item.path == '/portrait'"> |
102 | <p class="p1">学生画像</p> | 102 | <p class="p1">学生画像</p> |
103 | - <p class="p2">共分析{{ schoolInfo.imagesCount }}名学生成绩。</p> | 103 | + <!-- <p class="p2">共分析{{ schoolInfo.imagesCount }}名学生成绩。</p> --> |
104 | + <p class="p2">功能开发中。</p> | ||
104 | </div> | 105 | </div> |
105 | <div class="text" v-else-if="item.path == '/ask'"> | 106 | <div class="text" v-else-if="item.path == '/ask'"> |
106 | <p class="p1">随堂问报表</p> | 107 | <p class="p1">随堂问报表</p> |
src/views/login/index.vue
@@ -90,12 +90,12 @@ export default { | @@ -90,12 +90,12 @@ export default { | ||
90 | disableClick: true, | 90 | disableClick: true, |
91 | passwordType: "password", | 91 | passwordType: "password", |
92 | loginForm: { | 92 | loginForm: { |
93 | - username: "13610050254", | ||
94 | - password: "Pw050254#", | 93 | + // username: "13610050254", |
94 | + // password: "Pw050254#", | ||
95 | // username: "18946034886", | 95 | // username: "18946034886", |
96 | // password: "Pw034886#", | 96 | // password: "Pw034886#", |
97 | - // username: "18332123505", | ||
98 | - // password: "Pw123505#", | 97 | + username: "18332123505", |
98 | + password: "Pw123505#", | ||
99 | }, | 99 | }, |
100 | loginRules: { | 100 | loginRules: { |
101 | username: [ | 101 | username: [ |
src/views/portrait/index.vue
src/views/test/index.vue
@@ -27,7 +27,7 @@ | @@ -27,7 +27,7 @@ | ||
27 | multiple | 27 | multiple |
28 | collapse-tags | 28 | collapse-tags |
29 | v-model="query.subjectId" | 29 | v-model="query.subjectId" |
30 | - placeholder="" | 30 | + placeholder="选择科目" |
31 | @change="_QueryData" | 31 | @change="_QueryData" |
32 | > | 32 | > |
33 | <el-option | 33 | <el-option |
@@ -42,7 +42,7 @@ | @@ -42,7 +42,7 @@ | ||
42 | v-else | 42 | v-else |
43 | class="sel" | 43 | class="sel" |
44 | v-model="query.subjectId" | 44 | v-model="query.subjectId" |
45 | - placeholder="" | 45 | + placeholder="选择科目" |
46 | @change="_QueryData" | 46 | @change="_QueryData" |
47 | > | 47 | > |
48 | <el-option | 48 | <el-option |
@@ -175,7 +175,7 @@ | @@ -175,7 +175,7 @@ | ||
175 | > | 175 | > |
176 | <el-table-column label="操作" align="center"> | 176 | <el-table-column label="操作" align="center"> |
177 | <template slot-scope="scoped"> | 177 | <template slot-scope="scoped"> |
178 | - <el-tooltip effect="dark" content="详情" placement="left"> | 178 | + <el-tooltip effect="dark" content="详情" placement="top"> |
179 | <el-button | 179 | <el-button |
180 | type="primary" | 180 | type="primary" |
181 | circle | 181 | circle |
@@ -184,7 +184,7 @@ | @@ -184,7 +184,7 @@ | ||
184 | @click="linkTo(scoped.row)" | 184 | @click="linkTo(scoped.row)" |
185 | ></el-button> | 185 | ></el-button> |
186 | </el-tooltip> | 186 | </el-tooltip> |
187 | - <el-tooltip effect="dark" content="修改答案" placement="right"> | 187 | + <el-tooltip effect="dark" content="修改答案" placement="top"> |
188 | <el-button | 188 | <el-button |
189 | type="primary" | 189 | type="primary" |
190 | circle | 190 | circle |
@@ -371,31 +371,32 @@ export default { | @@ -371,31 +371,32 @@ export default { | ||
371 | xingming: "丁芳菲", | 371 | xingming: "丁芳菲", |
372 | totalScore: 5, | 372 | totalScore: 5, |
373 | rank: 1, | 373 | rank: 1, |
374 | - 周测卷20221130totalScore:10, | ||
375 | - 周测卷20221130rank:0, | ||
376 | - 周测卷20221131totalScore:11, | ||
377 | - 周测卷20221131rank:1, | ||
378 | - 周测卷20221132totalScore:12, | ||
379 | - 周测卷20221132rank:2, | ||
380 | - 周测卷20221132totalScore:13, | ||
381 | - 周测卷20221132rank:3, | 374 | + 周测卷20221130totalScore: 10, |
375 | + 周测卷20221130rank: 0, | ||
376 | + 周测卷20221131totalScore: 11, | ||
377 | + 周测卷20221131rank: 1, | ||
378 | + 周测卷20221132totalScore: 12, | ||
379 | + 周测卷20221132rank: 2, | ||
380 | + 周测卷20221132totalScore: 13, | ||
381 | + 周测卷20221132rank: 3, | ||
382 | }, | 382 | }, |
383 | { | 383 | { |
384 | xuehao: 2, | 384 | xuehao: 2, |
385 | xingming: "丁芳", | 385 | xingming: "丁芳", |
386 | totalScore: 4, | 386 | totalScore: 4, |
387 | rank: 2, | 387 | rank: 2, |
388 | - 周测卷20221130totalScore:20, | ||
389 | - 周测卷20221130rank:3, | ||
390 | - 周测卷20221131totalScore:21, | ||
391 | - 周测卷20221131rank:4, | ||
392 | - 周测卷20221132totalScore:22, | ||
393 | - 周测卷20221132rank:5, | ||
394 | - 周测卷20221132totalScore:22, | ||
395 | - 周测卷20221132rank:5, | 388 | + 周测卷20221130totalScore: 20, |
389 | + 周测卷20221130rank: 3, | ||
390 | + 周测卷20221131totalScore: 21, | ||
391 | + 周测卷20221131rank: 4, | ||
392 | + 周测卷20221132totalScore: 22, | ||
393 | + 周测卷20221132rank: 5, | ||
394 | + 周测卷20221132totalScore: 22, | ||
395 | + 周测卷20221132rank: 5, | ||
396 | }, | 396 | }, |
397 | ], | 397 | ], |
398 | - answerList: [//设置多卷内容供tabel表格数据用 | 398 | + answerList: [ |
399 | + //设置多卷内容供tabel表格数据用 | ||
399 | { | 400 | { |
400 | title: "周测卷20221130", | 401 | title: "周测卷20221130", |
401 | totalScore: 6, | 402 | totalScore: 6, |
@@ -415,10 +416,9 @@ export default { | @@ -415,10 +416,9 @@ export default { | ||
415 | }; | 416 | }; |
416 | }, | 417 | }, |
417 | async created() { | 418 | async created() { |
418 | - this.role = this.$store.getters.info.permissions[0]?.role || ""; | ||
419 | - if (this.role == "ROLE_BANZHUREN") { | ||
420 | - this.query.subjectId = []; | ||
421 | - } | 419 | + this.role = this.$store.getters.info.permissions.find( |
420 | + (item) => item.roleName == this.$store.getters.info.showRoleName | ||
421 | + )?.role; | ||
422 | await this._QueryClassList(); | 422 | await this._QueryClassList(); |
423 | await this._QuerySubjectList(); | 423 | await this._QuerySubjectList(); |
424 | // await this.setDate(1); | 424 | // await this.setDate(1); |
@@ -528,7 +528,7 @@ export default { | @@ -528,7 +528,7 @@ export default { | ||
528 | this.classList = data.list.map((item) => { | 528 | this.classList = data.list.map((item) => { |
529 | return { | 529 | return { |
530 | value: item.classId, | 530 | value: item.classId, |
531 | - label: item.clazzName, | 531 | + label: item.className, |
532 | }; | 532 | }; |
533 | }); | 533 | }); |
534 | this.query.classId = this.classList[0]?.value; | 534 | this.query.classId = this.classList[0]?.value; |
@@ -542,19 +542,21 @@ export default { | @@ -542,19 +542,21 @@ export default { | ||
542 | }); | 542 | }); |
543 | if (status === 0) { | 543 | if (status === 0) { |
544 | this.subjectList = | 544 | this.subjectList = |
545 | - data.list?.map((item) => { | 545 | + data.subjectNames?.map((item) => { |
546 | return { | 546 | return { |
547 | - value: item.subjectId, | ||
548 | - label: item.subjectName, | 547 | + value: item, |
548 | + label: item, | ||
549 | }; | 549 | }; |
550 | }) || []; | 550 | }) || []; |
551 | - if (this.role == "ROLE_BANZHUREN") { | 551 | + if (this.role == "ROLE_BANZHUREN") { |
552 | this.subjectList.unshift({ | 552 | this.subjectList.unshift({ |
553 | value: "", | 553 | value: "", |
554 | label: "全部", | 554 | label: "全部", |
555 | }); | 555 | }); |
556 | + this.query.subjectId = [this.subjectList[0]?.value]; | ||
557 | + }else{ | ||
558 | + this.query.subjectId = this.subjectList[0]?.value; | ||
556 | } | 559 | } |
557 | - this.query.subjectId = this.subjectList[0]?.value; | ||
558 | } else { | 560 | } else { |
559 | this.$message.error(info); | 561 | this.$message.error(info); |
560 | } | 562 | } |