|  | @@ -99,20 +99,21 @@
 | 
											
												
													
														|  |                    <!-- 
 |  |                    <!-- 
 | 
											
												
													
														|  |                      v-model="answerList[indexs].pinyin"
 |  |                      v-model="answerList[indexs].pinyin"
 | 
											
												
													
														|  |                     -->
 |  |                     -->
 | 
											
												
													
														|  | -                  <p class="pinyin" v-if="conent.pinyin != '__'">
 |  | 
 | 
											
												
													
														|  | 
 |  | +                  <p class="pinyin" v-if="conent.pinyin.indexOf('__')==-1">
 | 
											
												
													
														|  |                      {{ conent.pinyin }}
 |  |                      {{ conent.pinyin }}
 | 
											
												
													
														|  |                    </p>
 |  |                    </p>
 | 
											
												
													
														|  |                  </template>
 |  |                  </template>
 | 
											
												
													
														|  | -                <template v-if="conent.chs == '__'">
 |  | 
 | 
											
												
													
														|  | -                  <div
 |  | 
 | 
											
												
													
														|  | -                    contenteditable="true"
 |  | 
 | 
											
												
													
														|  | 
 |  | +                <template v-if="conent.chs.indexOf('__')>-1">
 | 
											
												
													
														|  | 
 |  | +                  <EditDiv class="input chs" v-model='curQue.Bookanswer[indexs].answerList[items.detail.resArr[conIndex].inputNumber].chs' :TaskModel="TaskModel"></EditDiv>
 | 
											
												
													
														|  | 
 |  | +                  <!-- <el-input
 | 
											
												
													
														|  |                      class="input chs"
 |  |                      class="input chs"
 | 
											
												
													
														|  | -                    v-html="answerList[indexs].chs"
 |  | 
 | 
											
												
													
														|  | -                    @change="changeAnswerList($event, indexs, 'chs')"
 |  | 
 | 
											
												
													
														|  | -                    @copy.native.capture.prevent="handleFalse"
 |  | 
 | 
											
												
													
														|  | -                    @paste.native.capture.prevent="handleFalse"
 |  | 
 | 
											
												
													
														|  | -                    @cut.native.capture.prevent="handleFalse"
 |  | 
 | 
											
												
													
														|  | -                  ></div>
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    type="textarea"
 | 
											
												
													
														|  | 
 |  | +                    autosize
 | 
											
												
													
														|  | 
 |  | +                    placeholder="输入"
 | 
											
												
													
														|  | 
 |  | +                    v-model="curQue.Bookanswer[indexs].answerList[items.detail.resArr[conIndex].inputNumber].chs"
 | 
											
												
													
														|  | 
 |  | +                    :readonly="TaskModel=='ANSWER'"
 | 
											
												
													
														|  | 
 |  | +                    maxlength="200">
 | 
											
												
													
														|  | 
 |  | +                </el-input> -->
 | 
											
												
													
														|  |                  </template>
 |  |                  </template>
 | 
											
												
													
														|  |                  <template v-else>
 |  |                  <template v-else>
 | 
											
												
													
														|  |                    <p class="chs">
 |  |                    <p class="chs">
 | 
											
										
											
												
													
														|  | @@ -130,7 +131,7 @@
 | 
											
												
													
														|  |                      v-html="answerList[indexs].pinyin"
 |  |                      v-html="answerList[indexs].pinyin"
 | 
											
												
													
														|  |                      @change="changeAnswerList($event, indexs, 'pinyin')"
 |  |                      @change="changeAnswerList($event, indexs, 'pinyin')"
 | 
											
												
													
														|  |                    ></div> -->
 |  |                    ></div> -->
 | 
											
												
													
														|  | -                  <p class="pinyin" v-if="conent.pinyin != '__'">
 |  | 
 | 
											
												
													
														|  | 
 |  | +                  <p class="pinyin" v-if="conent.pinyin.indexOf('__')==-1">
 | 
											
												
													
														|  |                      {{ conent.pinyin }}
 |  |                      {{ conent.pinyin }}
 | 
											
												
													
														|  |                    </p>
 |  |                    </p>
 | 
											
												
													
														|  |                  </template>
 |  |                  </template>
 | 
											
										
											
												
													
														|  | @@ -142,23 +143,23 @@
 | 
											
												
													
														|  |            <input
 |  |            <input
 | 
											
												
													
														|  |              @input="handleInput"
 |  |              @input="handleInput"
 | 
											
												
													
														|  |              :class="['item-input']"
 |  |              :class="['item-input']"
 | 
											
												
													
														|  | -            v-model="curQue.Bookanswer[indexs]"
 |  | 
 | 
											
												
													
														|  | 
 |  | +            v-model="curQue.Bookanswer[indexs].answer"
 | 
											
												
													
														|  |              placeholder="输入"
 |  |              placeholder="输入"
 | 
											
												
													
														|  |            />
 |  |            />
 | 
											
												
													
														|  |          </template>
 |  |          </template>
 | 
											
												
													
														|  |          <template v-if="dataType.indexOf('sentence_judge_chs') > -1">
 |  |          <template v-if="dataType.indexOf('sentence_judge_chs') > -1">
 | 
											
												
													
														|  | -          <div class="judge-box">
 |  | 
 | 
											
												
													
														|  | 
 |  | +          <div class="judge-box" :class="[TaskModel == 'ANSWER'?'notAllow':'']">
 | 
											
												
													
														|  |              <a
 |  |              <a
 | 
											
												
													
														|  |                :class="[
 |  |                :class="[
 | 
											
												
													
														|  |                  'right-btn',
 |  |                  'right-btn',
 | 
											
												
													
														|  | -                curQue.Bookanswer[indexs] == 'right' ? 'active' : '',
 |  | 
 | 
											
												
													
														|  | 
 |  | +                curQue.Bookanswer[indexs].answer == 'right' ? 'active' : '',
 | 
											
												
													
														|  |                ]"
 |  |                ]"
 | 
											
												
													
														|  |                @click="handleSelectJudge('right', indexs)"
 |  |                @click="handleSelectJudge('right', indexs)"
 | 
											
												
													
														|  |              ></a>
 |  |              ></a>
 | 
											
												
													
														|  |              <a
 |  |              <a
 | 
											
												
													
														|  |                :class="[
 |  |                :class="[
 | 
											
												
													
														|  |                  'error-btn',
 |  |                  'error-btn',
 | 
											
												
													
														|  | -                curQue.Bookanswer[indexs] == 'error' ? 'active' : '',
 |  | 
 | 
											
												
													
														|  | 
 |  | +                curQue.Bookanswer[indexs].answer == 'error' ? 'active' : '',
 | 
											
												
													
														|  |                ]"
 |  |                ]"
 | 
											
												
													
														|  |                @click="handleSelectJudge('error', indexs)"
 |  |                @click="handleSelectJudge('error', indexs)"
 | 
											
												
													
														|  |              ></a>
 |  |              ></a>
 | 
											
										
											
												
													
														|  | @@ -168,6 +169,9 @@
 | 
											
												
													
														|  |            <template v-if="dataType.indexOf('sentence_input_chs') != -1">
 |  |            <template v-if="dataType.indexOf('sentence_input_chs') != -1">
 | 
											
												
													
														|  |              <Soundrecord
 |  |              <Soundrecord
 | 
											
												
													
														|  |                @handleWav="handleWav"
 |  |                @handleWav="handleWav"
 | 
											
												
													
														|  | 
 |  | +              :answerRecordList="curQue.Bookanswer[indexs].recordList"
 | 
											
												
													
														|  | 
 |  | +              :tmIndex="indexs"
 | 
											
												
													
														|  | 
 |  | +              :TaskModel="TaskModel"
 | 
											
												
													
														|  |                type="normal"
 |  |                type="normal"
 | 
											
												
													
														|  |                v-if="items.IsRecord"
 |  |                v-if="items.IsRecord"
 | 
											
												
													
														|  |              />
 |  |              />
 | 
											
										
											
												
													
														|  | @@ -175,6 +179,9 @@
 | 
											
												
													
														|  |            <template v-else>
 |  |            <template v-else>
 | 
											
												
													
														|  |              <Soundrecord
 |  |              <Soundrecord
 | 
											
												
													
														|  |                @handleWav="handleWav"
 |  |                @handleWav="handleWav"
 | 
											
												
													
														|  | 
 |  | +              :answerRecordList="curQue.Bookanswer[indexs].recordList"
 | 
											
												
													
														|  | 
 |  | +              :tmIndex="indexs"
 | 
											
												
													
														|  | 
 |  | +              :TaskModel="TaskModel"
 | 
											
												
													
														|  |                type="mini"
 |  |                type="mini"
 | 
											
												
													
														|  |                class="luyin-box"
 |  |                class="luyin-box"
 | 
											
												
													
														|  |                v-if="items.IsRecord"
 |  |                v-if="items.IsRecord"
 | 
											
										
											
												
													
														|  | @@ -188,9 +195,10 @@
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  <script>
 |  |  <script>
 | 
											
												
													
														|  |  import Soundrecord from "../preview/Soundrecord.vue"; // 录音模板
 |  |  import Soundrecord from "../preview/Soundrecord.vue"; // 录音模板
 | 
											
												
													
														|  | 
 |  | +import EditDiv from "../preview/EditDiv.vue"
 | 
											
												
													
														|  |  export default {
 |  |  export default {
 | 
											
												
													
														|  | -  components: { Soundrecord },
 |  | 
 | 
											
												
													
														|  | -  props: ["curQue"],
 |  | 
 | 
											
												
													
														|  | 
 |  | +  components: { Soundrecord, EditDiv },
 | 
											
												
													
														|  | 
 |  | +  props: ["curQue","TaskModel"],
 | 
											
												
													
														|  |    data() {
 |  |    data() {
 | 
											
												
													
														|  |      return {
 |  |      return {
 | 
											
												
													
														|  |        audio: new Audio(),
 |  |        audio: new Audio(),
 | 
											
										
											
												
													
														|  | @@ -232,36 +240,50 @@ export default {
 | 
											
												
													
														|  |      handleData() {
 |  |      handleData() {
 | 
											
												
													
														|  |        let _this = this;
 |  |        let _this = this;
 | 
											
												
													
														|  |        this.dataType = [];
 |  |        this.dataType = [];
 | 
											
												
													
														|  | 
 |  | +      this.curQue.fn_list.forEach((item) => {
 | 
											
												
													
														|  | 
 |  | +        if (item.isFn) {
 | 
											
												
													
														|  | 
 |  | +          _this.dataType.push(item.type);
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  |        if (!this.curQue.Bookanswer) {
 |  |        if (!this.curQue.Bookanswer) {
 | 
											
												
													
														|  | 
 |  | +        let answerList = []
 | 
											
												
													
														|  |          let curCorrect = [];
 |  |          let curCorrect = [];
 | 
											
												
													
														|  |          this.curQue.option.forEach((item) => {
 |  |          this.curQue.option.forEach((item) => {
 | 
											
												
													
														|  | -          curCorrect.push("");
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if (this.dataType.indexOf("sentence_input_chs") != -1) {
 | 
											
												
													
														|  | 
 |  | +            answerList = []
 | 
											
												
													
														|  | 
 |  | +            item.answer.forEach((it) => {
 | 
											
												
													
														|  | 
 |  | +                answerList.push({
 | 
											
												
													
														|  | 
 |  | +                    chs: "",
 | 
											
												
													
														|  | 
 |  | +                    pinyin: "",
 | 
											
												
													
														|  | 
 |  | +                });
 | 
											
												
													
														|  | 
 |  | +            });
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        curCorrect.push({
 | 
											
												
													
														|  | 
 |  | +            answer: "",
 | 
											
												
													
														|  | 
 |  | +            recordList: [],
 | 
											
												
													
														|  | 
 |  | +            answerList: answerList
 | 
											
												
													
														|  | 
 |  | +          });
 | 
											
												
													
														|  |          });
 |  |          });
 | 
											
												
													
														|  |          this.$set(this.curQue, "Bookanswer", curCorrect);
 |  |          this.$set(this.curQue, "Bookanswer", curCorrect);
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      this.curQue.fn_list.forEach((item) => {
 |  | 
 | 
											
												
													
														|  | -        if (item.isFn) {
 |  | 
 | 
											
												
													
														|  | -          _this.dataType.push(item.type);
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -      });
 |  | 
 | 
											
												
													
														|  |        let curQue = JSON.parse(JSON.stringify(this.curQue));
 |  |        let curQue = JSON.parse(JSON.stringify(this.curQue));
 | 
											
												
													
														|  |        curQue.option.forEach((dItem, dIndex) => {
 |  |        curQue.option.forEach((dItem, dIndex) => {
 | 
											
												
													
														|  |          let paraArr = [];
 |  |          let paraArr = [];
 | 
											
												
													
														|  | 
 |  | +        let inputNumber = 0
 | 
											
												
													
														|  |          dItem.detail.wordsList.forEach((sItem, sIndex) => {
 |  |          dItem.detail.wordsList.forEach((sItem, sIndex) => {
 | 
											
												
													
														|  |            this.mergeWordSymbol(dItem.detail.wordsList, sItem, sIndex);
 |  |            this.mergeWordSymbol(dItem.detail.wordsList, sItem, sIndex);
 | 
											
												
													
														|  |            let obj = {
 |  |            let obj = {
 | 
											
												
													
														|  |              pinyin: sItem.pinyin,
 |  |              pinyin: sItem.pinyin,
 | 
											
												
													
														|  |              chs: sItem.chs,
 |  |              chs: sItem.chs,
 | 
											
												
													
														|  |              isShow: sItem.isShow,
 |  |              isShow: sItem.isShow,
 | 
											
												
													
														|  | 
 |  | +            inputNumber: sItem.chs.indexOf('__')>-1?inputNumber:''
 | 
											
												
													
														|  |            };
 |  |            };
 | 
											
												
													
														|  |            paraArr.push(obj);
 |  |            paraArr.push(obj);
 | 
											
												
													
														|  | 
 |  | +          if(sItem.chs.indexOf('__')>-1){
 | 
											
												
													
														|  | 
 |  | +              inputNumber++
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  |          });
 |  |          });
 | 
											
												
													
														|  |          this.$set(_this.curQue.option[dIndex].detail, "resArr", paraArr);
 |  |          this.$set(_this.curQue.option[dIndex].detail, "resArr", paraArr);
 | 
											
												
													
														|  | -        console.log();
 |  | 
 | 
											
												
													
														|  | -        if (paraArr.length == 0) {
 |  | 
 | 
											
												
													
														|  | -          let str = "就那天___";
 |  | 
 | 
											
												
													
														|  | -          let arrs = str.split(/_{2,}/g);
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  |        });
 |  |        });
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      //词和标点合一起
 |  |      //词和标点合一起
 | 
											
										
											
												
													
														|  | @@ -277,9 +299,14 @@ export default {
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      // 判断题选择
 |  |      // 判断题选择
 | 
											
												
													
														|  |      handleSelectJudge(obj, index) {
 |  |      handleSelectJudge(obj, index) {
 | 
											
												
													
														|  | -      this.$set(this.curQue.Bookanswer, index, obj);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if(!this.TaskModel||this.TaskModel!='ANSWER'){
 | 
											
												
													
														|  | 
 |  | +            this.curQue.Bookanswer[index].answer = obj
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    handleWav(list, tmIndex) {
 | 
											
												
													
														|  | 
 |  | +        tmIndex = tmIndex ? tmIndex : 0;
 | 
											
												
													
														|  | 
 |  | +        this.$set(this.curQue.Bookanswer[tmIndex], "recordList", list);
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  | -    handleWav(data) {},
 |  | 
 | 
											
												
													
														|  |      handleDatas(str, type) {
 |  |      handleDatas(str, type) {
 | 
											
												
													
														|  |        str = str.trim();
 |  |        str = str.trim();
 | 
											
												
													
														|  |        str = str.replace(/_{2,}/g, "^ ");
 |  |        str = str.replace(/_{2,}/g, "^ ");
 | 
											
										
											
												
													
														|  | @@ -288,12 +315,11 @@ export default {
 | 
											
												
													
														|  |        let resArr = type == "hanzi" ? str.split("") : str.split(/\s+/);
 |  |        let resArr = type == "hanzi" ? str.split("") : str.split(/\s+/);
 | 
											
												
													
														|  |        return resArr;
 |  |        return resArr;
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  | -    changeAnswerList(e, index, type) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    changeAnswerList(e, index, type, indexs) {
 | 
											
												
													
														|  |        if (type == "pinyin") {
 |  |        if (type == "pinyin") {
 | 
											
												
													
														|  | -        this.answerList[index].pinyin += e.target.innerHTML;
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.curQue.Bookanswer[index].answerList[indexs].pinyin += e.target.innerHTML;
 | 
											
												
													
														|  |        } else {
 |  |        } else {
 | 
											
												
													
														|  | -        this.answerList[index].chs += e.target.innerHTML;
 |  | 
 | 
											
												
													
														|  | -        console.log(e.target.innerHTML)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.curQue.Bookanswer[index].answerList[indexs].chs += e.target.innerHTML;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      handleFalse(){
 |  |      handleFalse(){
 | 
											
										
											
												
													
														|  | @@ -303,16 +329,6 @@ export default {
 | 
											
												
													
														|  |    //生命周期 - 创建完成(可以访问当前this实例)
 |  |    //生命周期 - 创建完成(可以访问当前this实例)
 | 
											
												
													
														|  |    created() {
 |  |    created() {
 | 
											
												
													
														|  |      this.handleData();
 |  |      this.handleData();
 | 
											
												
													
														|  | -    if (this.dataType.indexOf("sentence_input_chs") != -1) {
 |  | 
 | 
											
												
													
														|  | -      this.curQue.option.forEach((item) => {
 |  | 
 | 
											
												
													
														|  | -        item.answer.forEach((it) => {
 |  | 
 | 
											
												
													
														|  | -          this.answerList.push({
 |  | 
 | 
											
												
													
														|  | -            chs: "",
 |  | 
 | 
											
												
													
														|  | -            pinyin: "",
 |  | 
 | 
											
												
													
														|  | -          });
 |  | 
 | 
											
												
													
														|  | -        });
 |  | 
 | 
											
												
													
														|  | -      });
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    //生命周期 - 挂载完成(可以访问DOM元素)
 |  |    //生命周期 - 挂载完成(可以访问DOM元素)
 | 
											
												
													
														|  |    mounted() {
 |  |    mounted() {
 | 
											
										
											
												
													
														|  | @@ -400,7 +416,7 @@ export default {
 | 
											
												
													
														|  |              border-bottom: 1px solid black;
 |  |              border-bottom: 1px solid black;
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |            .pinyin {
 |  |            .pinyin {
 | 
											
												
													
														|  | -            font-weight: "GB-PINYINOK-B";
 |  | 
 | 
											
												
													
														|  | 
 |  | +            font-family: "GB-PINYINOK-B";
 | 
											
												
													
														|  |              font-size: 14px;
 |  |              font-size: 14px;
 | 
											
												
													
														|  |              line-height: 130%;
 |  |              line-height: 130%;
 | 
											
												
													
														|  |              color: rgba(0, 0, 0, 0.6);
 |  |              color: rgba(0, 0, 0, 0.6);
 | 
											
										
											
												
													
														|  | @@ -480,6 +496,11 @@ export default {
 | 
											
												
													
														|  |        .judge-box {
 |  |        .judge-box {
 | 
											
												
													
														|  |          display: flex;
 |  |          display: flex;
 | 
											
												
													
														|  |          justify-content: center;
 |  |          justify-content: center;
 | 
											
												
													
														|  | 
 |  | +        &.notAllow{
 | 
											
												
													
														|  | 
 |  | +            a,a.error-btn{
 | 
											
												
													
														|  | 
 |  | +                cursor: not-allowed;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  |          a {
 |  |          a {
 | 
											
												
													
														|  |            width: 32px;
 |  |            width: 32px;
 | 
											
												
													
														|  |            height: 32px;
 |  |            height: 32px;
 |