| | |
| | | <!--pages/bookServices/examination/questionList/index.wxml--> |
| | | <view class="question-list" style="background-color:{{isNight ? '#000' : '#fff'}}"> |
| | | <view |
| | | class="question-list" |
| | | style="background-color:{{isNight ? '#000' : '#fff'}}" |
| | | > |
| | | <!-- 题型title --> |
| | | <view class="question-title" wx:if="{{questionList[showIndex].type}}" style="background-color:{{isNight ? '#000' : '#fff'}}"> |
| | | <text class="title-name">{{questionList[showIndex].type}}</text><text class="title-score" style="color: {{isNight ? '#fff' : '#000'}};">(每题{{questionList[showIndex].score}}分)</text> |
| | | <view |
| | | class="question-title" |
| | | wx:if="{{questionList[showIndex].type}}" |
| | | style="background-color:{{isNight ? '#000' : '#fff'}}" |
| | | > |
| | | <text class="title-name">{{questionList[showIndex].type}}</text |
| | | ><text class="title-score" style="color: {{isNight ? '#fff' : '#000'}};" |
| | | >(每题{{questionList[showIndex].score}}分)</text |
| | | > |
| | | </view> |
| | | <!-- 题目列表 --> |
| | | <swiper class="swiper" bind:change="changeSwiper" current="{{currentIndex}}"> |
| | | <swiper-item wx:for="{{questionList}}" wx:key="{{item.id}}"> |
| | | <swiper-item wx:for="{{questionList}}" wx:key="{{id}}"> |
| | | <!-- 题干 --> |
| | | <view class="question-stem title-score" style="color: {{isNight ? '#fff' : '#000'}};"> |
| | | <view |
| | | class="question-stem title-score" |
| | | style="color: {{isNight ? '#fff' : '#000'}};" |
| | | > |
| | | <!-- 题号 --> |
| | | <text>{{item.number}}.</text> |
| | | <!-- 仅文字 --> |
| | | <view wx:if="{{item.stemStyle == 'Txt' && item.questionType != 'completion'}}">{{item.stem.stemTxt}}</view> |
| | | <view |
| | | wx:if="{{item.stemStyle == 'Txt' && item.questionType != 'completion'}}" |
| | | >{{item.stem.stemTxt}}</view |
| | | > |
| | | <!-- 仅图片 --> |
| | | <view wx:elif="{{item.stemStyle == 'Image'}}"> |
| | | <t-image src="{{item.stem.stemImage}}" /> |
| | | </view> |
| | | <!-- 图片加文字 --> |
| | | <view wx:elif="{{item.stemStyle == 'TxtAndImage'}}" class="title-TxtAndImage"> |
| | | <view |
| | | wx:elif="{{item.stemStyle == 'TxtAndImage'}}" |
| | | class="title-TxtAndImage" |
| | | > |
| | | <text>{{item.stem.stemTxt}}</text> |
| | | <t-image src="{{item.stem.stemImage}}"></t-image> |
| | | </view> |
| | | <!-- 富文本 --> |
| | | <view wx:elif="{{item.stemStyle == 'RichText'}} " class="title-RichText"> |
| | | <view |
| | | wx:elif="{{item.stemStyle == 'RichText'}} " |
| | | class="title-RichText" |
| | | > |
| | | <rich-text nodes="{{item.stem.stemTxt}}"></rich-text> |
| | | </view> |
| | | <!-- 填空题 --> |
| | | <view wx:if="{{item.questionType == 'completion'}}"> |
| | | <view class="completion-box" wx:for="{{item.stem}}" wx:for-item="inputItem" wx:for-index="inputIndex" wx:key="inputIndex"> |
| | | <t-input disabled="{{item.isComplete}}" bind:change="onChangeInput" data-value="{{item.option}}" data-id="{{item.id}}" data-index="{{inputItem.num}}" class="title-input" style="{{inputstyle}}" placeholder-style="{{placeholderstyle}}" wx:if="{{inputItem.data == 'input'}}" placeholder="请输入文字" value="{{item.userAnswer[inputItem.num]}}"></t-input> |
| | | <view |
| | | class="completion-box" |
| | | wx:for="{{item.stem}}" |
| | | wx:for-item="inputItem" |
| | | wx:for-index="inputIndex" |
| | | wx:key="inputIndex" |
| | | > |
| | | <t-input |
| | | disabled="{{item.isComplete}}" |
| | | bind:change="onChangeInput" |
| | | data-value="{{item.option}}" |
| | | data-id="{{item.id}}" |
| | | data-index="{{inputItem.num}}" |
| | | class="title-input" |
| | | style="{{inputstyle}}" |
| | | placeholder-style="{{placeholderstyle}}" |
| | | wx:if="{{inputItem.data == 'input'}}" |
| | | placeholder="请输入文字" |
| | | value="{{item.userAnswer[inputItem.num]}}" |
| | | ></t-input> |
| | | <text wx:else>{{inputItem}}</text> |
| | | </view> |
| | | </view> |
| | |
| | | <!-- 答题区域 --> |
| | | <view class="question-answer"> |
| | | <!-- 单选题 --> |
| | | <t-radio-group wx:if="{{item.questionType == 'singleChoice' || item.questionType == 'judge'}}" defaultValue="{{item.userAnswer}}" disabled="{{item.isComplete}}" bind:change="onChangeRadio" class="radio-group" data-value="{{item.option}}" data-id="{{item.id}}"> |
| | | <view wx:for="{{item.option}}" wx:for-item="contentItem" wx:for-index="contentIndex" wx:key="contentIndex"> |
| | | <t-radio value="{{contentItem.value}}" icon="none" placement="right" borderless style="color: {{isNight ? '#fff' : '#000'}}; background-color:{{isNight ? '#000' : '#fff'}}"> |
| | | <view class="radio-item {{item.answer == contentItem.value && item.answer == item.userAnswer ? 'radio-correct' : item.userAnswer == contentItem.value && item.userAnswer != item.answer ?'radio-error' :''}}" style="color: {{isNight ? '#fff' : '#000'}}; background-color:{{isNight ? '#000' : '#fff'}}"> |
| | | <t-radio-group |
| | | wx:if="{{item.questionType == 'singleChoice' || item.questionType == 'judge'}}" |
| | | defaultValue="{{item.userAnswer}}" |
| | | disabled="{{item.isComplete}}" |
| | | bind:change="onChangeRadio" |
| | | class="radio-group" |
| | | data-value="{{item.option}}" |
| | | data-id="{{item.id}}" |
| | | > |
| | | <view |
| | | wx:for="{{item.option}}" |
| | | wx:for-item="contentItem" |
| | | wx:for-index="contentIndex" |
| | | wx:key="contentIndex" |
| | | > |
| | | <t-radio |
| | | value="{{contentItem.value}}" |
| | | icon="none" |
| | | placement="right" |
| | | borderless |
| | | > |
| | | <view |
| | | class="radio-item {{(answerType == 'option' || answerType == 'mock' ) && !submitStatus && item.userAnswer == contentItem.value ? 'radio-active' : ''}} {{ (item.answer == contentItem.value && item.answer == item.userAnswer && submitStatus) ? 'radio-correct' : (item.userAnswer == contentItem.value && item.userAnswer != item.answer && submitStatus) ?'radio-error' :'' }}" |
| | | > |
| | | <!-- 仅文字 --> |
| | | <text wx:if="{{item.optionStyle == 'Txt'}}">{{contentItem.value}}、{{contentItem.txt}}</text> |
| | | <text wx:if="{{item.optionStyle == 'Txt'}}" |
| | | >{{contentItem.value}}、{{contentItem.txt}}</text |
| | | > |
| | | <!-- 仅图片 --> |
| | | <view wx:if="{{item.optionStyle == 'Image'}}" class="fl-center"> |
| | | <text>{{contentItem.value}}、</text> |
| | | <t-image src="{{contentItem.img}}"></t-image> |
| | | </view> |
| | | <!-- 文字加图片 --> |
| | | <view wx:if="{{item.optionStyle == 'TxtAndImage'}}" class="fl-center"> |
| | | <view |
| | | wx:if="{{item.optionStyle == 'TxtAndImage'}}" |
| | | class="fl-center" |
| | | > |
| | | <text>{{contentItem.value}}、</text> |
| | | <text>{{contentItem.txt}}</text> |
| | | <t-image src="{{contentItem.img}}"></t-image> |
| | |
| | | <text>{{contentItem.value}}、</text> |
| | | <rich-text nodes="{{contentItem.txt}}"></rich-text> |
| | | </view> |
| | | <text wx:if="{{item.answer == contentItem.value && item.answer == item.userAnswer}}">对</text> |
| | | <text wx:if="{{item.userAnswer == contentItem.value && item.userAnswer != item.answer}}">错</text> |
| | | <text |
| | | wx:if="{{submitStatus && (item.answer == contentItem.value && item.answer == item.userAnswer)}}" |
| | | >对</text |
| | | > |
| | | <text |
| | | wx:if="{{ submitStatus && (item.userAnswer == contentItem.value && item.userAnswer != item.answer)}}" |
| | | >错</text |
| | | > |
| | | </view> |
| | | </t-radio> |
| | | </view> |
| | | </t-radio-group> |
| | | <!-- 多选题 --> |
| | | <t-checkbox-group disabled="{{item.isComplete}}" class="checkbox-group" wx:elif="{{item.questionType == 'multipleChoice'}}" t-class="box" borderless bind:change="onChangeRadio" data-value="{{item.option}}" data-id="{{item.id}}" defaultValue="{{item.userAnswer}}"> |
| | | <view wx:for="{{item.option}}" wx:for-item="contentItem" wx:for-index="contentIndex" wx:key="contentIndex"> |
| | | <t-checkbox-group |
| | | disabled="{{item.isComplete}}" |
| | | class="checkbox-group" |
| | | wx:elif="{{item.questionType == 'multipleChoice'}}" |
| | | t-class="box" |
| | | borderless |
| | | bind:change="onChangeRadio" |
| | | data-value="{{item.option}}" |
| | | data-id="{{item.id}}" |
| | | defaultValue="{{item.userAnswer}}" |
| | | > |
| | | <view |
| | | wx:for="{{item.option}}" |
| | | wx:for-item="contentItem" |
| | | wx:for-index="contentIndex" |
| | | wx:key="contentIndex" |
| | | > |
| | | <t-checkbox block="{{false}}" value="{{contentItem.value}}"> |
| | | <!-- 仅文字 --> |
| | | <text wx:if="{{item.optionStyle == 'Txt'}}">{{contentItem.value}}、{{contentItem.txt}}</text> |
| | | <text wx:if="{{item.optionStyle == 'Txt'}}" |
| | | >{{contentItem.value}}、{{contentItem.txt}}</text |
| | | > |
| | | <!-- 仅图片 --> |
| | | <view wx:if="{{item.optionStyle == 'Image'}}" class="fl-center"> |
| | | <text>{{contentItem.value}}、</text> |
| | | <t-image src="{{contentItem.img}}"></t-image> |
| | | </view> |
| | | <!-- 文字加图片 --> |
| | | <view wx:if="{{item.optionStyle == 'TxtAndImage'}}" class="fl-center"> |
| | | <view |
| | | wx:if="{{item.optionStyle == 'TxtAndImage'}}" |
| | | class="fl-center" |
| | | > |
| | | <text>{{contentItem.value}}、</text> |
| | | <text>{{contentItem.txt}}</text> |
| | | <t-image src="{{contentItem.img}}"></t-image> |
| | |
| | | </view> |
| | | </t-checkbox-group> |
| | | <!-- 简答 翻译 --> |
| | | <t-textarea disabled="{{item.isComplete}}" value="{{item.userAnswer}}" bind:change="onChangeRadio" data-value="{{item.option}}" data-id="{{item.id}}" class="option-textarea" wx:elif="{{item.questionType == 'shortAnswer'}}" t-class="external-class" placeholder="请输入文字" bordered maxlength="500" disableDefaultPadding="{{true}}" indicator style="{{style}}" /> |
| | | <t-textarea |
| | | disabled="{{item.isComplete}}" |
| | | value="{{item.userAnswer}}" |
| | | bind:change="onChangeRadio" |
| | | data-value="{{item.option}}" |
| | | data-id="{{item.id}}" |
| | | class="option-textarea" |
| | | wx:elif="{{item.questionType == 'shortAnswer'}}" |
| | | t-class="external-class" |
| | | placeholder="请输入文字" |
| | | bordered |
| | | maxlength="500" |
| | | disableDefaultPadding="{{true}}" |
| | | indicator |
| | | style="{{style}}" |
| | | /> |
| | | </view> |
| | | <!-- 解析 --> |
| | | <view class="analysis" wx:if="{{item.isComplete}}"> |
| | | <!-- 单选、多选解析 --> |
| | | <view |
| | | class="analysis" |
| | | wx:if="{{item.isComplete && (item.questionType == 'singleChoice' || item.questionType == 'judge' || item.questionType == 'multipleChoice')}}" |
| | | > |
| | | <view class="analysis-answer"> |
| | | <view class="answer-correct"> |
| | | <view class="answer-correct answer-center"> |
| | | <text class="analysis-title-box">正确答案:</text> |
| | | <rich-text nodes="{{item.answer}}" style="font-size: 40rpx"></rich-text> |
| | | <rich-text |
| | | nodes="{{item.answer}}" |
| | | style="font-size: 40rpx" |
| | | ></rich-text> |
| | | </view> |
| | | <view class="answer-error"> |
| | | <text class="analysis-title-box">您的答案:</text><text class="answer-text">{{item.userAnswer}}</text> |
| | | <view |
| | | class="answer-center marginL {{item.isRight ? 'answer-correct' : 'answer-error'}}" |
| | | wx:if="{{item.questionType !== 'shortAnswer'}}" |
| | | > |
| | | <text class="analysis-title-box">您的答案:</text |
| | | ><text class="answer-text">{{item.userAnswer}}</text> |
| | | </view> |
| | | </view> |
| | | <view class="analysis-text" wx:if="{{item.analysisCon}}"> |
| | | 答案解析:<rich-text nodes="{{item.analysisCon}}" class="analysis-content"></rich-text> |
| | | <view |
| | | class="analysis-text" |
| | | wx:if="{{item.analysisCon}}" |
| | | style="color: {{isNight ? '#fff' : '#000'}};" |
| | | > |
| | | 答案解析:<rich-text |
| | | nodes="{{item.analysisCon}}" |
| | | class="analysis-content" |
| | | ></rich-text> |
| | | </view> |
| | | </view> |
| | | <!-- 填空、简答解析 --> |
| | | <view |
| | | class="analysis" |
| | | wx:if="{{(item.questionType == 'shortAnswer' || item.questionType == 'completion') && item.isComplete}}" |
| | | > |
| | | <view |
| | | style="display: {{item.questionType == 'completion' ? 'flex' : 'block'}}" |
| | | > |
| | | <text |
| | | wx:if="{{item.questionType == 'completion'}}" |
| | | class="short-answer-fz answer-correct" |
| | | >正确答案:</text |
| | | > |
| | | <text |
| | | wx:if="{{item.questionType == 'shortAnswer'}}" |
| | | class="short-answer-fz" |
| | | > |
| | | 参考答案: |
| | | </text> |
| | | <rich-text |
| | | wx:if="{{item.questionType == 'shortAnswer'}}" |
| | | nodes="{{item.answer}}" |
| | | style="font-size: 28rpx; color:{{item.questionType == 'completion' ? '#1FBC1F' : '#000'}}" |
| | | ></rich-text> |
| | | <view |
| | | wx:if="{{item.questionType == 'completion'}}" |
| | | class="short-answer-fz answer-correct" |
| | | >{{item.answer}}</view |
| | | > |
| | | </view> |
| | | <view |
| | | wx:if="{{item.questionType == 'completion'}}" |
| | | class="short-answer-mr" |
| | | style="display: {{item.questionType == 'completion' ? 'flex' : 'block'}}" |
| | | > |
| | | <text |
| | | class="short-answer-fz {{item.isRight ? 'answer-correct' : 'answer-error'}}" |
| | | >您的答案:</text |
| | | > |
| | | <view |
| | | class="short-answer-fz {{item.isRight ? 'answer-correct' : 'answer-error'}}" |
| | | >{{item.userAnswer}}</view |
| | | > |
| | | </view> |
| | | <view class="short-answer-mr"> |
| | | <text class="short-answer-fz">答案解析:</text> |
| | | <rich-text |
| | | nodes="{{item.analysisCon}}" |
| | | style="font-size: 28rpx" |
| | | ></rich-text> |
| | | </view> |
| | | </view> |
| | | </swiper-item> |
| | | <swiper-item> |
| | | <swiper-item wx:if="{{answerType !== 'collectQuestion'}}"> |
| | | <text>没有更多了。。。</text> |
| | | </swiper-item> |
| | | </swiper> |
| | | </view> |
| | | </view> |