Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
educationStu
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
向伟
educationStu
Commits
d636ab64
Commit
d636ab64
authored
Sep 22, 2021
by
zhengke
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改
parent
95dc6497
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
1593 additions
and
980 deletions
+1593
-980
Calculation.vue
src/components/subject/Calculation.vue
+61
-25
Cloze.vue
src/components/subject/Cloze.vue
+44
-6
Dataquestion.vue
src/components/subject/Dataquestion.vue
+67
-30
EntryProblem.vue
src/components/subject/EntryProblem.vue
+67
-30
FillInTheBlanks.vue
src/components/subject/FillInTheBlanks.vue
+66
-29
ListenTopic.vue
src/components/subject/ListenTopic.vue
+516
-557
MultipleChoice.vue
src/components/subject/MultipleChoice.vue
+75
-39
Other.vue
src/components/subject/Other.vue
+66
-29
SharingChoose.vue
src/components/subject/SharingChoose.vue
+40
-2
SingleChoice.vue
src/components/subject/SingleChoice.vue
+66
-32
SingleChoiceNumber.vue
src/components/subject/SingleChoiceNumber.vue
+74
-37
SortingProblem.vue
src/components/subject/SortingProblem.vue
+40
-2
Spoken.vue
src/components/subject/Spoken.vue
+59
-22
easyQuestion.vue
src/components/subject/easyQuestion.vue
+61
-25
judge.vue
src/components/subject/judge.vue
+63
-27
nounExplanation.vue
src/components/subject/nounExplanation.vue
+61
-25
readingCompre.vue
src/components/subject/readingCompre.vue
+95
-38
shortAnswer.vue
src/components/subject/shortAnswer.vue
+61
-24
examScore.vue
src/pages/exam/examScore.vue
+11
-1
No files found.
src/components/subject/Calculation.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -47,7 +47,6 @@
item1
.
Answer
}}
</view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
...
...
@@ -72,6 +71,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -162,6 +166,14 @@ export default {
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -182,6 +194,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -226,7 +262,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/Cloze.vue
View file @
d636ab64
...
...
@@ -17,7 +17,7 @@
}" :autoplay="autoplay" :current="current" @change="onchange">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -69,12 +69,16 @@
</view>
</template>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate&&item1.AnswerParse"
style=
"margin-top:20px;"
>
<view
style=
"margin-top: 20rpx; word-wrap: break-word"
>
<view
style=
"word-wrap: break-word;display: flex;align-items: center;"
>
<text
style=
"color: #8c8a94"
>
解析:
</text>
<text
style=
"color: #000"
>
{{ item1.AnswerParse }}
</text>
<view
style=
"color: #000"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
...
...
@@ -174,6 +178,14 @@
}
});
});
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
...
...
@@ -195,6 +207,31 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -265,6 +302,7 @@
.item1
{
align-items
:
center
;
overflow
:
auto
;
}
.item2
{
...
...
src/components/subject/Dataquestion.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -51,7 +51,6 @@
<view
class=
"viewAnswerContent"
v-html=
"item2.Content"
></view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
您的答案:
...
...
@@ -81,6 +80,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -169,6 +173,14 @@ export default {
});
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -189,6 +201,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -255,6 +291,7 @@ export default {
.item1
{
align-items
:
center
;
overflow-y
:
auto
;
}
.item2
{
...
...
@@ -276,7 +313,7 @@ export default {
}
.chooseName
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-family
:
PingFang
SC
;
font-weight
:
500
;
color
:
#111111
;
...
...
src/components/subject/EntryProblem.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -51,7 +51,6 @@
<view
class=
"viewAnswerContent"
v-html=
"item2.Content"
></view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
您的答案:
...
...
@@ -81,6 +80,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -174,6 +178,14 @@ export default {
});
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -194,6 +206,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -236,7 +272,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
@@ -258,6 +294,7 @@ export default {
.item1
{
align-items
:
center
;
overflow-y
:
auto
;
}
.item2
{
...
...
src/components/subject/FillInTheBlanks.vue
View file @
d636ab64
...
...
@@ -20,7 +20,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -47,7 +47,6 @@
<view
class=
"viewAnswerContent"
v-html=
"item2.Content"
></view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
您的答案:
...
...
@@ -77,6 +76,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -162,6 +166,14 @@ export default {
return
e
.
Content
!=
""
&&
e
.
Content
;
});
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -181,6 +193,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -243,6 +279,7 @@ export default {
.item1
{
align-items
:
center
;
overflow
:
auto
;
}
.item2
{
...
...
src/components/subject/ListenTopic.vue
View file @
d636ab64
...
...
@@ -8,25 +8,20 @@
<text
class=
"Exam_Score"
>
(共
{{
data
.
DetailsList
.
length
}}
道,
{{
data
.
GScore
}}
分)
</text>
</view>
<view
class=
"ExamIndex_Box"
>
<text
class=
"Single_Before"
>
{{
ExamIndex
}}
</
text
>
/
<text
class=
"Exam_Total"
>
{{
data
.
DetailsList
.
length
}}
</text>
<text
class=
"Single_Before"
>
{{
ExamIndex
}}
</text>
/
<
text
class=
"Exam_Total"
>
{{
data
.
DetailsList
.
length
}}
</text>
</view>
</view>
<swiper
class=
"swiper-box"
:style=
"
{
<swiper
class=
"swiper-box"
:style=
"
{
height: `calc(100vh - 300rpx - ${statusBarHeight}px)`,
}"
:autoplay="autoplay"
:current="current"
@change="onchange"
:skip-hidden-item-layout="true"
>
}" :autoplay="autoplay" :current="current" @change="onchange" :skip-hidden-item-layout="true">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"flex flex_start_center"
>
<audio
style=
"text-align: left"
poster=
"https://bjetxgzv.cdn.bspapp.com/VKCEYUGU-uni-app-doc/7fbf26a0-4f4a-11eb-b680-7980c8a877b8.png"
:src=
"item1.Src"
name=
"日语听力"
:action=
"audioAction"
controls
></audio>
<audio
style=
"text-align: left"
poster=
"https://bjetxgzv.cdn.bspapp.com/VKCEYUGU-uni-app-doc/7fbf26a0-4f4a-11eb-b680-7980c8a877b8.png"
:src=
"item1.Src"
name=
"日语听力"
:action=
"audioAction"
controls
></audio>
<!--
<view
class=
"audioBox flex flex_center_center"
@
click=
"audioManage(item1.Src)"
...
...
@@ -45,170 +40,100 @@
/>
</view>
-->
</view>
<view
class=
"questionView"
:style=
"
{
height: `calc(100vh - 334rpx - ${statusBarHeight}px)`,
}"
>
<view
v-for=
"(item2, index2) in item1.QuestionContentObj"
:key=
"index2"
class=
"item2"
>
<view
class=
"questionView"
:style=
"
{
height: `calc(100vh - 549rpx)`,
}">
<view
v-for=
"(item2, index2) in item1.QuestionContentObj"
:key=
"index2"
class=
"item2"
>
<view
class=
"flex questionTitle"
>
<view
>
{{
index2
+
1
}}
、(
{{
<view>
{{
index2
+
1
}}
、(
{{
item2
.
QuestionName
.
slice
(
0
,
2
)
}}
)
</view
>
}}
)
</view>
<view
v-html=
"item2.SubTitle"
></view>
<text
class=
".Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
<view
v-for=
"(item3, index3) in item2.SubAnwser"
:key=
"index3"
>
<!-- 单选 、判断-->
<view
class=
"flex flex_start_center item3"
v-if=
"
<view
class=
"flex flex_start_center item3"
v-if=
"
item2.QuestionKey === 'single' ||
item2.QuestionKey === 'judge'
"
>
"
>
<template
v-if=
"isOperate"
>
<view
class=
"chooseNum"
:class=
"
{ myAnswer: item3.IsAnswer }"
@click="singerChange(item2, item3)"
>
{{
item3
.
Name
}}
<view
class=
"chooseNum"
:class=
"
{ myAnswer: item3.IsAnswer }"
@click="singerChange(item2, item3)">
{{
item3
.
Name
}}
</view>
<view
class=
"chooseName"
@
click=
"singerChange(item2, item3)"
v-html=
"item3.Content"
></view>
<view
class=
"chooseName"
@
click=
"singerChange(item2, item3)"
v-html=
"item3.Content"
></view>
</
template
>
<
template
v-else
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }">
{{
item3
.
Name
}}
</view>
<view
class=
"chooseName"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
v-html="item3.Content"
>
</view>
<view
class=
"chooseName"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
v-html="item3.Content">
</view>
</
template
>
</view>
<!-- 多选 -->
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'multiple'"
>
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'multiple'"
>
<
template
v-if=
"isOperate"
>
<view
class=
"chooseNum"
:class=
"
{ myAnswer: item3.IsAnswer }"
@click="multipleChange(item2, item3)"
>
{{
item3
.
Name
}}
<view
class=
"chooseNum"
:class=
"
{ myAnswer: item3.IsAnswer }"
@click="multipleChange(item2, item3)">
{{
item3
.
Name
}}
</view>
<view
class=
"chooseName"
@
click=
"multipleChange(item2, item3)"
v-html=
"item3.Content"
></view>
<view
class=
"chooseName"
@
click=
"multipleChange(item2, item3)"
v-html=
"item3.Content"
></view>
</
template
>
<
template
v-else
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }">
{{
item3
.
Name
}}
</view>
<view
class=
"chooseName"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
v-html="item3.Content"
>
</view>
<view
class=
"chooseName"
:class=
"
{ isTrueAnswer: item3.IsAnswer }"
v-html="item3.Content">
</view>
</
template
>
</view>
<!-- 填空 -->
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'fill-in'"
>
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'fill-in'"
>
<view
class=
"chooseNum"
>
{{ index3 + 1 }}
</view>
<
template
v-if=
"isOperate"
>
<input
v-for=
"cItem in item2.SubAnwser"
type=
"text"
v-model=
"cItem.Content"
class=
"chooseName chooseName2"
placeholder=
"请填写答案"
@
input=
"AnswerChange(item2)"
/>
<input
v-for=
"cItem in item2.SubAnwser"
type=
"text"
v-model=
"cItem.Content"
class=
"chooseName chooseName2"
placeholder=
"请填写答案"
@
input=
"AnswerChange(item2)"
/>
</
template
>
<
template
v-else
>
<view
v-for=
"cItem in item2.SubAnwser"
class=
"viewAnswerContent"
v-html=
"cItem.Content"
></view>
<view
v-for=
"cItem in item2.SubAnwser"
class=
"viewAnswerContent"
v-html=
"cItem.Content"
></view>
</
template
>
</view>
<!-- 简答 -->
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'short-answer'"
>
<view
class=
"flex flex_start_center item3"
v-if=
"item2.QuestionKey === 'short-answer'"
>
<
template
v-if=
"isOperate"
>
<textarea
type=
"text"
v-for=
"cItem in item2.SubAnwser"
v-model=
"cItem.Content"
class=
"chooseName chooseName2"
placeholder=
"请填写答案"
@
input=
"AnswerChange(item2)"
/>
<textarea
type=
"text"
v-for=
"cItem in item2.SubAnwser"
v-model=
"cItem.Content"
class=
"chooseName chooseName2"
placeholder=
"请填写答案"
@
input=
"AnswerChange(item2)"
/>
</
template
>
<
template
v-else
>
<view
v-for=
"cItem in item2.SubAnwser"
class=
"viewAnswerContent"
v-html=
"cItem.Content"
></view>
<view
v-for=
"cItem in item2.SubAnwser"
class=
"viewAnswerContent"
v-html=
"cItem.Content"
></view>
</
template
>
</view>
</view>
<
template
v-if=
"!isOperate"
>
<
template
v-if=
"!isOperate"
>
<view
class=
"AnswerContent"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
<text
class=
"isTrueAnswer"
>
{{
item1
.
QuestionAnswerList
[
index2
].
SubAnswer
}}
</text
>
,
}}
</text>
,
<text>
您的答案:
<template
v-if=
"item1.AnswerList && item1.AnswerList.length > 0"
>
<text
v-if=
"
<template
v-if=
"item1.AnswerList && item1.AnswerList.length > 0"
>
<text
v-if=
"
item1.QuestionAnswerList[index2].SubAnswer ==
item1.AnswerList[index2].SubAnswer
"
class=
"isTrueAnswer"
>
"
class=
"isTrueAnswer"
>
{{
item1
.
AnswerList
[
index2
].
SubAnswer
}}
,回答正确
</text>
<text
v-else
class=
"isNotAnswer"
>
<template
v-if=
"item1.AnswerList[index2].SubAnswer != ''"
>
<template
v-if=
"item1.AnswerList[index2].SubAnswer != ''"
>
{{
item1
.
AnswerList
[
index2
].
SubAnswer
}}
,回答错误
</
template
>
<
template
v-else
>
未回答
</
template
>
...
...
@@ -216,16 +141,11 @@
</template>
</text>
</view>
<view
style=
"margin-top: 20rpx"
v-if=
"item1.AnswerList[index2].StudentScore!=''||item1.AnswerList[index2].StudentScore===0"
>
<view
style=
"margin-top: 20rpx"
v-if=
"item1.AnswerList[index2].StudentScore!=''||item1.AnswerList[index2].StudentScore===0"
>
<text
style=
"color: #8c8a94"
>
您的得分:
</text>
<text
class=
"isTrueAnswer"
v-if=
"item1.AnswerList[index2].StudentScore > 0"
>
{{ item1.AnswerList[index2].StudentScore }}
</text
>
<text
class=
"isTrueAnswer"
v-if=
"item1.AnswerList[index2].StudentScore > 0"
>
{{ item1.AnswerList[index2].StudentScore }}
</text>
<text
class=
"isNotAnswer"
v-else
>
{{
item1.AnswerList[index2].StudentScore
}}
</text>
...
...
@@ -235,20 +155,15 @@
</view>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"
!isOperate &&
item1.AnswerParse
"
>
<view
class=
"AnswerContent"
v-if=
"!isOperate && item1.AnswerParse"
>
<view
style=
"word-wrap: break-word"
>
<text
style=
"color: #8c8a94"
>
解析:
</text>
<view
style=
"color: #000; display: inline-block"
v-html=
"item1.AnswerParse"
></view>
<view
style=
"color: #000; display: inline-block"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
...
...
@@ -259,7 +174,7 @@
</template>
<
script
>
import
{
import
{
ref
,
reactive
,
toRefs
,
...
...
@@ -269,11 +184,13 @@ import {
computed
,
onMounted
,
onUnmounted
,
}
from
"vue"
;
import
{
changeNumToHan
}
from
"../../utils/index"
;
const
innerAudioContext
=
uni
.
createInnerAudioContext
();
innerAudioContext
.
autoplay
=
true
;
export
default
{
}
from
"vue"
;
import
{
changeNumToHan
}
from
"../../utils/index"
;
const
innerAudioContext
=
uni
.
createInnerAudioContext
();
innerAudioContext
.
autoplay
=
true
;
export
default
{
props
:
{
paperData
:
Object
,
sort
:
Number
,
...
...
@@ -284,7 +201,9 @@ export default {
ExamStatus
:
Number
,
},
setup
(
props
,
context
)
{
let
{
refs
}
=
getCurrentInstance
();
let
{
refs
}
=
getCurrentInstance
();
console
.
log
(
163
,
refs
);
let
data
=
reactive
({
autoplay
:
false
,
...
...
@@ -347,7 +266,7 @@ export default {
uni
.
navigateBack
();
},
//获取总时长
getTotalTime
(
url
)
{
getTotalTime
(
url
)
{
innerAudioContext
.
src
=
url
;
var
Inner
=
''
;
innerAudioContext
.
onCanplay
(()
=>
{
...
...
@@ -442,6 +361,14 @@ export default {
this
.
$emit
(
"getBeforeTopic"
);
}
},
//点击上一题
getBeforeExam
()
{
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
()
{
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -463,10 +390,40 @@ export default {
...
methods
,
};
},
};
};
</
script
>
<
style
>
.name
{
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
font-family
:
PingFang
SC
;
...
...
@@ -475,70 +432,71 @@ export default {
display
:
flex
;
align-items
:
center
;
justify-content
:
space-between
;
}
}
.ExamIndex_Box
{
.ExamIndex_Box
{
margin-right
:
40
rpx
;
}
}
.Single_Before
{
font-size
:
28
rpx
;
.Single_Before
{
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
}
.isTrueAnswer
{
.isTrueAnswer
{
color
:
green
!important
;
}
}
.isNotAnswer
{
.isNotAnswer
{
color
:
red
!important
;
}
}
.AnswerContent
{
.AnswerContent
{
font-size
:
30
rpx
;
padding
:
25
rpx
;
background-color
:
#f4f4f4
;
border-radius
:
5px
;
}
}
.viewAnswerContent
{
.viewAnswerContent
{
width
:
100%
;
min-height
:
44
rpx
;
border-bottom
:
1px
solid
#d1d1d1
;
padding-bottom
:
5px
;
}
}
.Exam_Total
{
.Exam_Total
{
font-size
:
25
rpx
;
color
:
gray
;
}
}
.swiper-box
{
.swiper-box
{
height
:
calc
(
100vh
-
270
rpx
);
box-sizing
:
border-box
;
}
}
.num
{
.num
{
font-size
:
30
rpx
;
font-family
:
PingFang
SC
;
color
:
#111111
;
}
}
.item
{
.item
{
/* margin-bottom: 40rpx; */
position
:
relative
;
}
}
.item1
{
.item1
{
/* margin: 25rpx 0; */
align-items
:
center
;
}
}
.questionView
{
.questionView
{
overflow-y
:
auto
;
}
.audioBox
{
}
.audioBox
{
width
:
120
rpx
;
height
:
30
rpx
;
background
:
#b4ddfe
;
...
...
@@ -548,25 +506,25 @@ export default {
font-family
:
PingFang
SC
;
font-weight
:
500
;
color
:
#00acf9
;
}
}
.item2
{
.item2
{
box-sizing
:
border-box
;
margin
:
30
rpx
0
;
/* padding: 0 30rpx; */
}
}
.item3
{
.item3
{
padding-left
:
25
rpx
;
margin
:
20
rpx
0
;
}
}
.myAnswer
{
.myAnswer
{
background-color
:
#00acf9
!important
;
color
:
#ffffff
!important
;
}
}
.chooseNum
{
.chooseNum
{
width
:
50
rpx
;
height
:
50
rpx
;
text-align
:
center
;
...
...
@@ -578,33 +536,34 @@ export default {
font-family
:
PingFang
SC
;
font-weight
:
bold
;
color
:
#111111
;
}
}
.chooseName
{
.chooseName
{
font-size
:
30
rpx
;
font-family
:
PingFang
SC
;
font-weight
:
500
;
color
:
#111111
;
}
}
.chooseName2
{
.chooseName2
{
flex-grow
:
1
;
border-bottom
:
1px
solid
#111
;
}
}
.questionTitle
{
.questionTitle
{
font-size
:
28
rpx
;
font-family
:
PingFang
SC
;
font-weight
:
bold
;
color
:
#111111
;
}
}
.listen
.van-count-down
{
.listen
.van-count-down
{
font-size
:
22
rpx
!important
;
color
:
#00acf9
!important
;
}
.Exam_Score
{
color
:
#999999
;
font-size
:
28
rpx
;
}
}
.Exam_Score
{
color
:
#999999
;
font-size
:
28
rpx
;
}
</
style
>
src/components/subject/MultipleChoice.vue
View file @
d636ab64
...
...
@@ -25,7 +25,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
...
...
@@ -61,7 +61,6 @@
</view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
...
...
@@ -100,6 +99,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -188,6 +192,14 @@ export default {
this
.
$emit
(
"getBeforeTopic"
);
}
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -209,6 +221,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
src/components/subject/Other.vue
View file @
d636ab64
...
...
@@ -17,7 +17,7 @@
}" :autoplay="autoplay" :current="current" @change="onchange">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -29,9 +29,8 @@
</view>
</
template
>
<
template
v-else
>
<view
class=
"viewAnswerContent"
style=
"margin
-top:20px
;"
v-html=
"item1.Answer"
></view>
<view
class=
"viewAnswerContent"
style=
"margin
:20px 0
;"
v-html=
"item1.Answer"
></view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
...
...
@@ -59,6 +58,11 @@
<view
style=
"color: #000; display: inline-block"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -150,6 +154,14 @@
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -170,6 +182,31 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
padding
:
0
20px
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -212,7 +249,7 @@
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/SharingChoose.vue
View file @
d636ab64
...
...
@@ -17,7 +17,7 @@
}" :autoplay="autoplay" :current="current" @change="onchange">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
style=
"padding: 0 20px"
>
<view
class=
"item1"
style=
"padding: 0 20px"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<template
v-if=
"item1.QuestionContentObj[1] && item1.QuestionContentObj[1].length > 0"
>
<view
class=
"num"
>
(1)
</view>
...
...
@@ -78,6 +78,10 @@
</view>
</template>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -203,6 +207,14 @@
}
return
Array
;
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -223,6 +235,32 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
padding
:
0
20px
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -266,7 +304,7 @@
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/SingleChoice.vue
View file @
d636ab64
...
...
@@ -12,13 +12,11 @@
class=
"Exam_Total"
>
{{
data
.
DetailsList
.
length
}}
</text>
</view>
</view>
<swiper
class=
"swiper-box"
:style=
"
{
height: `calc(100vh - 300rpx - ${statusBarHeight}px)`,
}" :autoplay="autoplay" :current="current" @change="onchange" :skip-hidden-item-layout="true"
<swiper
class=
"swiper-box"
:style=
"
{height: `calc(100vh - 300rpx - ${statusBarHeight}px)`}" :autoplay="autoplay" :current="current" @change="onchange" :skip-hidden-item-layout="true"
:disable-programmatic-animation="true">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex flex_start_center"
>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
...
...
@@ -38,7 +36,6 @@
</view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
...
...
@@ -65,6 +62,11 @@
<view
style=
"color: #000"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
>
<!-- 最后一页 -->
...
...
@@ -172,6 +174,14 @@
url
:
"/pages/exam/answerSheet"
,
});
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -192,6 +202,30 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -219,7 +253,7 @@
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/SingleChoiceNumber.vue
View file @
d636ab64
...
...
@@ -25,7 +25,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex flex_start_center"
>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
...
...
@@ -62,7 +62,6 @@
</view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
...
...
@@ -99,6 +98,11 @@
<view
style=
"color: #000"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
>
<!-- 最后一页 -->
...
...
@@ -202,6 +206,14 @@ export default {
url
:
"/pages/exam/answerSheet"
,
});
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -222,6 +234,31 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
padding
:
0
20px
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -249,7 +286,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/SortingProblem.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
style=
"padding: 0 20px"
>
<view
class=
"item1"
style=
"padding: 0 20px"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -116,6 +116,10 @@
</view>
</template>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -241,6 +245,14 @@ export default {
}
return
Array
;
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -261,6 +273,31 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
padding
:
0
20px
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -302,7 +339,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
@@ -324,6 +361,7 @@ export default {
.item1
{
align-items
:
center
;
overflow-y
:
auto
;
}
.item2
{
...
...
src/components/subject/Spoken.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -43,9 +43,8 @@
</view>
</
template
>
<
template
v-else
>
<view
class=
"viewAnswerContent"
style=
"margin
-top:15px
;"
v-html=
"item1.Answer"
></view>
<view
class=
"viewAnswerContent"
style=
"margin
:20px 0
;"
v-html=
"item1.Answer"
></view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
您的答案:
...
...
@@ -66,6 +65,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -153,6 +157,14 @@ export default {
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
()
{
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
()
{
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -173,6 +185,31 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
padding
:
0
20px
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -212,7 +249,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/easyQuestion.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -47,7 +47,6 @@
item1
.
Answer
}}
</view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
...
...
@@ -72,6 +71,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -162,6 +166,14 @@ export default {
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -182,6 +194,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
@@ -226,7 +262,7 @@ export default {
}
.Single_Before
{
font-size
:
28
rpx
;
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
...
...
src/components/subject/judge.vue
View file @
d636ab64
...
...
@@ -17,7 +17,7 @@
}" :autoplay="autoplay" :current="current" @change="onchange">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
...
...
@@ -36,7 +36,6 @@
</view>
</
template
>
</view>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
...
...
@@ -64,6 +63,11 @@
<view
style=
"color: #000; display: inline-block"
v-html=
"item1.AnswerParse"
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -158,6 +162,14 @@
if
(
e
.
detail
.
current
==
0
&&
data
.
sortIndex
!=
1
)
{
this
.
$emit
(
"getBeforeTopic"
);
}
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
...
...
@@ -179,6 +191,30 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
src/components/subject/nounExplanation.vue
View file @
d636ab64
...
...
@@ -24,7 +24,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -43,9 +43,8 @@
</view>
</
template
>
<
template
v-else
>
<view
class=
"viewAnswerContent"
>
{{
item1
.
Answer
}}
</view>
<view
class=
"viewAnswerContent"
style=
"margin-top:30rpx;"
>
{{
item1
.
Answer
}}
</view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
...
...
@@ -70,6 +69,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -160,6 +164,14 @@ export default {
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -180,6 +192,30 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
src/components/subject/readingCompre.vue
View file @
d636ab64
...
...
@@ -17,14 +17,17 @@
}" :autoplay="autoplay" :current="current" @change="onchange">
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view
class=
"num readTitle"
:style=
"
{ paddingBottom: `${questionH}rpx` }"
v-html="item1.Title">
</view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
<view
class=
"num readTitle"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
</view>
<view
class=
"questionBox"
:style=
"
{ height: `${questionH}rpx` }">
<
!--
<
view
class=
"questionBox"
:style=
"
{ height: `${questionH}rpx` }">
<view
class=
"questionTotal"
@
touchstart=
"touchstart"
@
touchmove=
"touchmove"
@
touchend=
"touchend"
>
本阅读理解共5小题
</view>
@
touchend=
"touchend"
>
本阅读理解共5小题
</view>
-->
<view
:style=
"
{maxHeight: `calc(100vh - 450rpx - ${statusBarHeight}px)`}"
style="overflow-y: auto;">
<view
style=
"margin:30rpx;"
class=
"Exam_Score"
>
本阅读理解共
{{
item1
.
QuestionContentObj
.
length
}}
小题
</view>
<template
v-if=
"isOperate"
>
<view
class=
"questionView"
>
<view
v-for=
"(item2, index2) in item1.QuestionContentObj"
:key=
"index2"
...
...
@@ -33,13 +36,13 @@
<view
style=
"white-space: nowrap"
>
{{
index2
+
1
}}
、(
{{
item2
.
QuestionName
.
slice
(
0
,
2
)
}}
)
</view>
<view
v-html=
"item2.SubTitle"
></view>
(
{{
item2
.
SubScore
}}
)
<view
v-html=
"item2.SubTitle"
></view>
<text
class=
"Exam_Score"
>
(
{{
item2
.
SubScore
}}
)
</text>
</view>
<view
v-for=
"(item3, index3) in item2.SubAnwser"
:key=
"index3"
>
<!-- 单选 、判断-->
<view
class=
"flex flex_start_center item3"
v-if=
"
item2.QuestionKey === 'single' ||
item2.QuestionKey === 'judge'
item2.QuestionKey === 'judge'
||item2.QuestionKey === 'single-number'
"
>
<view
class=
"chooseNum"
:class=
"
{ myAnswer: item3.IsAnswer }"
@click="singerChange(item2, item3)">
{{
item3
.
Name
}}
...
...
@@ -80,12 +83,15 @@
<view
v-for=
"(item2, index2) in item1.QuestionContentObj"
:key=
"index2"
class=
"item2"
>
<view
class=
"flex questionTitle"
>
<view
style=
"white-space: nowrap"
>
{{
index2
+
1
}}
、(
{{
item2
.
QuestionName
.
slice
(
0
,
2
)
}}
)
</view>
<view
v-html=
"item2.SubTitle"
></view>
(
{{
item2
.
SubScore
}}
)
<view
style=
"white-space: nowrap"
>
{{
index2
+
1
}}
、(
{{
item2
.
QuestionName
.
slice
(
0
,
2
)
}}
)
</view>
<view
v-html=
"item2.SubTitle"
></view><text
class=
"Exam_Score"
>
(
{{
item2
.
SubScore
}}
)
</text>
</view>
<view
v-for=
"(item3, index3) in item2.SubAnwser"
:key=
"index3"
>
<!-- 单选 、判断-->
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'single' || item2.QuestionKey === 'judge'"
>
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'single' || item2.QuestionKey === 'judge'||item2.QuestionKey === 'single-number'"
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }">
{{
item3
.
Name
}}
</view>
...
...
@@ -94,8 +100,7 @@
</view>
<!-- 多选 -->
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'multiple'"
>
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'multiple'"
>
<view
class=
"chooseNum"
:class=
"
{ isTrueAnswer: item3.IsAnswer }">
{{
item3
.
Name
}}
</view>
...
...
@@ -103,49 +108,55 @@
v-html="item3.Content">
</view>
</view>
<!-- 填空 -->
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'fill-in'"
>
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'fill-in'"
>
<view
class=
"chooseNum"
>
{{
index3
+
1
}}
</view>
<view
v-html=
"item3.Content"
class=
"chooseName"
></view>
</view>
<!-- 简答 -->
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'short-answer'"
>
<view
class=
"flex item3"
v-if=
"item2.QuestionKey === 'short-answer'"
>
<view
v-html=
"item3.Content"
class=
"chooseName"
></view>
</view>
</view>
<view
class=
"AnswerContent"
>
<view>
<text
style=
"color: #8c8a94"
>
正确答案:
</text>
<text
class=
"isTrueAnswer"
>
{{
item1
.
QuestionAnswerList
[
index2
].
SubAnswer
}}
</text>
,
<text
class=
"isTrueAnswer"
>
{{
item1
.
QuestionAnswerList
[
index2
].
SubAnswer
}}
</text>
,
<text>
您的答案:
<template
v-if=
"item1.AnswerList && item1.AnswerList.length>0"
>
<text
v-if=
"item1.QuestionAnswerList[index2].SubAnswer == item1.AnswerList[index2].SubAnswer"
class=
"isTrueAnswer"
>
<text
v-if=
"item1.QuestionAnswerList[index2].SubAnswer == item1.AnswerList[index2].SubAnswer"
class=
"isTrueAnswer"
>
{{
item1
.
AnswerList
[
index2
].
SubAnswer
}}
</text>
<text
v-else
class=
"isNotAnswer"
>
{{
item1
.
AnswerList
[
index2
].
SubAnswer
}}
,回答错误
</text>
</
template
>
<
template
v-else
>
<text>
未作答
</text>
<text
v-if=
"item1.AnswerList[index2].SubAnswer!=''"
class=
"isNotAnswer"
>
{{
item1
.
AnswerList
[
index2
].
SubAnswer
}}
,回答错误
</text>
<text
v-if=
"item1.AnswerList[index2].SubAnswer==''"
class=
"isNotAnswer"
>
未作答
</text>
</
template
>
</text>
</view>
<view
style=
"margin-top:20rpx;"
v-if=
"item1.AnswerList[index2].StudentScore!=''||item1.AnswerList[index2].StudentScore===0"
>
<view
style=
"margin-top:20rpx;"
v-if=
"item1.AnswerList[index2].StudentScore!=''||item1.AnswerList[index2].StudentScore===0"
>
<text
style=
"color:#8c8a94"
>
您的得分:
</text>
<text
class=
"isTrueAnswer"
v-if=
"item1.AnswerList[index2].StudentScore>0"
>
{{item1.AnswerList[index2].StudentScore}}
</text>
<text
class=
"isNotAnswer"
v-else
>
{{item1.AnswerList[index2].StudentScore}}
</text>
<text
class=
"isTrueAnswer"
v-if=
"item1.AnswerList[index2].StudentScore>0"
>
{{item1.AnswerList[index2].StudentScore}}
</text>
<text
class=
"isNotAnswer"
v-else
>
{{item1.AnswerList[index2].StudentScore}}
</text>
</view>
</view>
</view>
<view
style=
"word-wrap: break-word; margin: 0 30rpx 30rpx 30rpx"
<view
style=
"word-wrap: break-word; margin: 0 30rpx 30rpx 30rpx
;display: flex;align-items: center;
"
class=
"AnswerContent"
v-if=
"item1.AnswerParse"
>
<text
style=
"color: #8c8a94"
>
解析:
</text>
<
text
style=
"color: #000"
>
{{ item1.AnswerParse }}
</text
>
<
view
style=
"color: #000"
v-html=
"item1.AnswerParse"
></view
>
</view>
</view>
</template>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -195,7 +206,7 @@
timeOutEvent
:
false
,
statusBarHeight
:
0
,
isOperate
:
props
.
isOperate
,
ExamStatus
:
props
.
ExamStatus
ExamStatus
:
props
.
ExamStatus
});
//判断是否是第一大题
if
(
data
.
sortIndex
===
1
)
{
...
...
@@ -284,6 +295,14 @@
data
.
timeOutEvent
=
false
;
clearTimeout
(
data
.
timer
);
},
//点击上一题
getBeforeExam
()
{
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
()
{
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
console
.
log
(
361
,
data
.
data
);
...
...
@@ -305,6 +324,37 @@
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
30
rpx
;
padding
:
0
40
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.item
{
/* margin-bottom: 40rpx; */
position
:
relative
;
...
...
@@ -322,6 +372,7 @@
box-sizing
:
border-box
;
padding
:
0
30
rpx
;
}
.isTrueAnswer
{
color
:
green
!important
;
}
...
...
@@ -331,7 +382,7 @@
}
.ExamIndex_Box
{
margin-right
:
4
0
rpx
;
margin-right
:
4
8
rpx
;
}
.Exam_Total
{
...
...
@@ -350,16 +401,21 @@
font-family
:
PingFang
SC
;
color
:
#111111
;
box-sizing
:
border-box
;
}
.readTitle
img
{
max-width
:
100%
;
}
.Single_Before
{
font-size
:
30
rpx
;
font-weight
:
bold
;
color
:
#da7878
;
}
.item1
{
height
:
100%
;
align-items
:
center
;
overflow-y
:
auto
;
/* overflow-y: auto; */
box-sizing
:
border-box
;
padding
:
0
30
rpx
;
}
...
...
@@ -380,7 +436,7 @@
.questionView
{
height
:
100%
;
overflow-y
:
auto
;
/* overflow-y: auto; */
box-sizing
:
border-box
;
padding-bottom
:
80
rpx
;
}
...
...
@@ -395,15 +451,14 @@
}
.questionTitle
{
font-size
:
2
6
rpx
;
font-size
:
2
8
rpx
;
font-family
:
PingFang
SC
;
font-weight
:
bold
;
color
:
#111111
;
}
.item2
{
box-sizing
:
border-box
;
margin-bottom
:
6
0
rpx
;
margin-bottom
:
5
0
rpx
;
padding
:
0
30
rpx
;
}
...
...
@@ -419,6 +474,7 @@
.item3
{
padding-left
:
25
rpx
;
margin
:
20
rpx
0
;
align-items
:
center
;
}
.chooseNum
{
...
...
@@ -462,8 +518,9 @@
border-radius
:
10
rpx
;
font-size
:
28
rpx
;
}
.Exam_Score
{
color
:
#999999
;
font-size
:
28
rpx
;
.Exam_Score
{
color
:
#999999
;
font-size
:
28
rpx
;
}
</
style
>
src/components/subject/shortAnswer.vue
View file @
d636ab64
...
...
@@ -26,7 +26,7 @@
>
<swiper-item
v-if=
"sortIndex != 1"
></swiper-item>
<swiper-item
v-for=
"(item1, index1) in data.DetailsList"
:key=
"index1"
>
<view
class=
"item1"
>
<view
class=
"item1"
:style=
"
{height: `calc(100vh - 390rpx - ${statusBarHeight}px)`}"
>
<view
class=
"flex"
>
<view>
{{
index1
+
1
}}
、
</view>
<view
class=
"num"
v-html=
"item1.Title"
></view><text
class=
"Exam_Score"
>
(
{{
item1
.
Score
}}
)
</text>
...
...
@@ -46,7 +46,6 @@
<
template
v-else
>
<view
class=
"viewAnswerContent"
v-html=
"item2.Answer"
></view>
</
template
>
</view>
<view
class=
"AnswerContent"
v-if=
"!isOperate"
...
...
@@ -71,6 +70,11 @@
></view>
</view>
</view>
</view>
<view
class=
"AnswerBtn clear"
>
<view
class=
"AnswerBtnFirst"
@
click=
"getBeforeExam()"
v-if=
"ExamIndex!=1||sortIndex!=1"
>
上一题
</view>
<view
class=
"AnswerBtnSecond"
v-if=
"sortIndex != sortTotal"
@
click=
"getNextExam()"
>
下一题
</view>
</view>
</swiper-item>
<swiper-item
v-if=
"sortIndex != sortTotal"
></swiper-item>
</swiper>
...
...
@@ -156,6 +160,14 @@ export default {
}
context
.
emit
(
"answerChange"
,
data
.
data
);
},
//点击上一题
getBeforeExam
(){
data
.
current
=
data
.
current
-
1
;
},
//点击下一题
getNextExam
(){
data
.
current
=
data
.
current
+
1
;
}
};
onMounted
(()
=>
{
if
(
props
.
isLast
)
{
...
...
@@ -176,6 +188,31 @@ export default {
};
</
script
>
<
style
scoped
>
.AnswerBtn
{
margin-top
:
20
rpx
;
}
.clear
{
clear
:
both
}
.AnswerBtnFirst
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
border
:
1px
solid
#00ACF9
;
color
:
#00ACF9
;
float
:
left
;
}
.AnswerBtnSecond
{
width
:
250
rpx
;
height
:
60
rpx
;
text-align
:
center
;
line-height
:
60
rpx
;
border-radius
:
10
rpx
;
background-color
:
#00ACF9
;
color
:
#fff
;
float
:
right
;
}
.name
{
height
:
90
rpx
;
font-size
:
30
rpx
;
...
...
src/pages/exam/examScore.vue
View file @
d636ab64
...
...
@@ -110,9 +110,19 @@ export default {
if
(
res
)
{
if
(
res
.
Code
==
1
)
{
data
.
dataList
=
res
.
Data
;
let
Remark
=
''
if
(
res
.
Data
.
TotalScore
>
0
&&
res
.
Data
.
TotalScore
<=
60
){
Remark
=
'要加油哦'
}
if
(
res
.
Data
.
TotalScore
>
60
&&
res
.
Data
.
TotalScore
<=
90
){
Remark
=
'不错哦'
}
if
(
res
.
Data
.
TotalScore
>
90
){
Remark
=
'你好棒'
}
that
.
initCanvas
(
res
.
Data
.
TotalScore
,
res
.
Data
.
StuComment
,
Remark
,
res
.
Data
.
ExamScore
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment