本文為大家分享了微信小程序?qū)崿F(xiàn)多選功能的具體代碼,供大家參考,具體內(nèi)容如下
創(chuàng)新互聯(lián)公司-云計(jì)算及IDC服務(wù)提供商,涵蓋公有云、IDC機(jī)房租用、成都移動(dòng)機(jī)房、等保安全、私有云建設(shè)等企業(yè)級(jí)互聯(lián)網(wǎng)基礎(chǔ)服務(wù),服務(wù)熱線:18980820575
代碼:
{{num + 1}}/{{quesyion.length}} {{question[num][0]}}A {{question[num][1]}}B {{question[num][2]}}C {{question[num][3]}}D {{question[num][4]}}正確答案{{question[num][3]}} 確定 {{con}} 提交答卷
CSS:
/* hotblood_gongkao/pages/answer/answer.wxss */ /* title */ .titleImg{ width: 734rpx; height: 45rpx; position: fixed; top: 0; display: flex; flex-direction: row; align-items: center; left: 50%; background: #fbfbfb; margin-left: -367rpx; z-index: 10; } .titleImg image{ height: 35rpx; width: 100%; } /* end */ page{ height: 100%; width: 100%; background: #fbfbfb; } .isHide{ display: none; } .isShow{ display: block; } .title{ font-size: 34rpx; color: #a6a6a6; margin: 69rpx 0 0 0; display: flex; flex-direction: column; justify-content: center; align-items: center; } .answer-list{ } .answer-child{ width: 672rpx; margin: 0 auto; background: #fff; border-radius: 20rpx; padding-top:34rpx; margin-bottom: 20rpx; margin-top: 72rpx; box-sizing: border-box; box-shadow: 0 0 4rpx #dcdcdc; } .answer-title{ font-size: 32rpx; margin: 0 0 0 52rpx; } .answer-options{ display: flex; flex-direction: column; width: 642rpx; margin: 32rpx auto 0 auto; } .options{ width: 100%; height: 72rpx; line-height: 72rpx; font-size: 32rpx; padding-left: 30rpx; box-sizing: border-box; margin-bottom: 4rpx; position: relative; border: 2rpx solid #fff; } .dui{ position: absolute; height: 41rpx; width: 59rpx; top:50%; margin-top: -20rpx; right: 16rpx; display: none; } .dui2{ display: block!important; } .select{ border: 2rpx solid #4ab07e; box-sizing: border-box; } .submit{ height: 120rpx; width: 100%; background: #4ab07e; color: #fff; font-size: 34rpx; line-height: 120rpx; text-align: center; position: fixed; left: 0; bottom: 0; } /* 正確答案 */ .answer{ width: 100%; text-align: center; color: #ff122f; font-size: 34rpx; font-weight: bold; margin-top: 64rpx; } /* end */ /* 下一題 */ .subBtn{ width: 304rpx; height: 86rpx; background: #4ab07e; color: #fff; font-size: 34rpx; text-align: center; line-height: 86rpx; border-radius: 20rpx; margin: 190rpx auto 0 auto; }
js:
// hotblood_gongkao/pages/answer/answer.js const app = getApp(); Page({ /** * 頁(yè)面的初始數(shù)據(jù) */ data: { question: [ ["今天是個(gè)好日子", "halou word", "java", "javascript", 'c#'], ["今天是個(gè)好日子", "halou word", "java", "javascript", 'c#'], ], //題庫(kù) index: 0, //選擇的索引 wrong: [], //錯(cuò)誤 border: '', num: 0, con: '下一題', isOne: true, isWan: false, iswancheng: false, isque: false, whether: false, correct: [], //正確 duiList: 0, //答對(duì)的個(gè)數(shù) cuoList: 0, //答錯(cuò)的個(gè)數(shù) selectIndex: [{ sureid: false }, { sureid: false }, { sureid: false }, { sureid: false }, ], }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載 */ onLoad: function(options) { this.setData({ }) }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面初次渲染完成 */ onReady: function() { }, // 提交答卷 submit: function(e) { console.log(this.data.duiList); console.log(this.data.cuoList); var num = this.data.num; //當(dāng)前題目下標(biāo) var question = this.data.question; //題庫(kù) var duiList = this.data.duiList; //答對(duì)多少題 var cuoList = this.data.cuoList; //答錯(cuò)多少題 //獲得題目對(duì)象的長(zhǎng)度 var arr = Object.keys(question); var len = arr.length; if ((num + 1) == len) { var grade = (100 / len) * duiList; console.log(grade); wx.redirectTo({ url: '../chengjiu/chengjiu?grade=' + grade, }) } }, // 確認(rèn)選擇 confirm: function() { var num = this.data.num; var question = this.data.question; //題庫(kù) //獲得題目對(duì)象的長(zhǎng)度 var arr = Object.keys(question); var len = arr.length; if ((num + 1) == len) { this.setData({ iswancheng: true, isOne: true, isWan: true, isque: false }) } else { this.setData({ isOne: false, whether: true, isque: false, isWan: true }) } }, // 下一題 next: function() { var num = this.data.num; //當(dāng)前題目下標(biāo) this.setData({ num: num + 1, isOne: true, isWan: false, whether: false, index: 0 }) }, // 選擇答案 selectAnswer: function(e) { console.log(e); var index1 = e.currentTarget.dataset.index - 1; //當(dāng)前點(diǎn)擊元素的自定義數(shù)據(jù),這個(gè)很關(guān)鍵 var selectIndex = this.data.selectIndex; //取到data里的selectIndex selectIndex[index1].sureid = !selectIndex[index1].sureid; //點(diǎn)擊就賦相反的值 console.log(selectIndex[index1]) this.setData({ selectIndex: selectIndex //將已改變屬性的json數(shù)組更新 }) console.log(this.data.selectIndex.in_array(true)) if (selectIndex.in_array(true) == false) { this.setData({ isque: false }) } else { var question = this.data.question; //題庫(kù) var num = this.data.num; //當(dāng)前題目下標(biāo) var text = e.currentTarget.dataset.text; //選擇的答案 var duiList = this.data.duiList; //答對(duì)多少題 var cuoList = this.data.cuoList; //答錯(cuò)多少題 //獲得題目對(duì)象的長(zhǎng)度 var arr = Object.keys(question); var len = arr.length; //當(dāng)前答題為最后一題 if ((num + 1) == len) { //判斷選擇的答案和正確答案是否一致 if (text == question[num][3]) { duiList = duiList + 1; this.setData({ duiList: duiList, isque: true }) } else { cuoList = cuoList + 1; this.setData({ cuoList: cuoList, isque: true }) } } else { //判斷選擇的答案和正確答案是否一致 if (text == question[num][3]) { duiList = duiList + 1; this.setData({ duiList: duiList, isque: true }) } else { cuoList = cuoList + 1; this.setData({ cuoList: cuoList, isque: true }) } } } }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面顯示 */ onShow: function() { this.question(); }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面隱藏 */ onHide: function() { }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面卸載 */ onUnload: function() { }, /** * 頁(yè)面相關(guān)事件處理函數(shù)--監(jiān)聽(tīng)用戶下拉動(dòng)作 */ onPullDownRefresh: function() { }, /** * 頁(yè)面上拉觸底事件的處理函數(shù) */ onReachBottom: function() { }, /** * 用戶點(diǎn)擊右上角分享 */ onShareAppMessage: function() { } }) Array.prototype.in_array = function(element) { for (var i = 0; i < this.length; i++) { if (this[i].sureid == element) { return true; } } return false; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。