1. Request answer interface 2. Determine whether the user's answer is correct. If the answer is correct, jump to the next question. If the answer is wrong, a pop-up window will be displayed to inform the user that there is a wrong answer and ask the user to answer the question again. <div class="active_title"> <span>{{ orderTitle }}</span> </div> <p v-show="toanswer" ref="question">{{ title }}</p> <div class="answer-btns" @click="answerClick($event)"> <span class="answer-btn" :class="`${isRight && item.result == 1?'right':''}`" v-for="item in answer" :data-result='item.result'>{{ item.name }} <i class="iconfont icon-wrong"></i><i v-show="isRight && item.result == 1" class="iconfont icon-right"></i> </span> </div> getAllData() { this.$axios.get(answer interface).then((res)=>{ if(parseInt(res.data.errCode)>=0){ this.allData=res.data.data if(this.allData.question.length > 0) { this.toanswer = true } this.title = this.allData.question[0].title // Which question this.answer = this.allData.question[0].answer // Which question }else{ this.toast = this.$createToast({ txt: res.data.message, type: 'txt' }) this.toast.show() } }).catch((err)=>{ console.log(err) }) }, answerClick(e) { const tar = e.target, className = e.target.className if(className == "answer-btn") { this.mask = true const result = tar.dataset.result if(result == 1){ // console.log('Select the right one',result); this.isRight = true $(tar).addClass('right') } else { // console.log('wrong choice',result); this.isRight = true this.isWrong = true $(tar).addClass('wrong') setTimeout(() => { this.maskTips = true }, 1200); } setTimeout( () => { this.clickNum++ if(this.clickNum > 2) { this.clickNum = 2 if(this.isWrong) { console.log('wrong answer'); this.mask = false this.maskTips = true return false } else { console.log('Correct answer'); } } $('.answer-btn').removeClass('wrong') this.orderTitle = this.orderTitles[this.clickNum] this.isRight = this.mask = false this.title = this.allData.question[this.clickNum].title this.answer = this.allData.question[this.clickNum].answer },1200) } }, The above is the detailed content of Vue’s answering function. For more information about Vue’s answering function, please pay attention to other related articles on 123WORDPRESS.COM! You may also be interested in:
|
<<: MYSQL local installation and problem solving
>>: Tomcat multi-port domain name access and configuration to enable gzip compression method
Anyone who has read my articles recently knows th...
introduction Currently, k8s is very popular, and ...
The sort command is very commonly used, but it al...
Knowing which for loop or iterator is right for o...
Overview (official has more detailed description)...
Today I got familiar with the mouse zooming effect...
1. Execute the select statement first to generate...
Table of contents 1. What is virtual dom? 2. Why ...
Table of contents 1. Problem Description 2. Probl...
Table of contents 1. Picture above 2. User does n...
I installed MySQL smoothly in Ubuntu 16.04 before...
1. Background A sql-killer process is set up on e...
Table of contents Tomcat Download Tutorial Tomcat...
Table of contents PXE implements unattended batch...
Table of contents MySQL Constraint Operations 1. ...