| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482 | <template>	<view>		<view class="top">			<view class="title">				做题统计				<text>(不含简答和案例题)</text>			</view>						<view class="circle-wrap">				<view class="circle-list">					<view class="item">						<canvas class="canvas" canvas-id="Canvas1"></canvas>						<view class="text">正确率</view>					</view>					<view class="item">						<canvas  canvas-id="Canvas2"></canvas>						<view class="text">做题进度</view>					</view>					<view class="numbers">						<view class="blue">已答  {{goodsCount.doNum}}</view>						<view>总数  {{goodsCount.totalNum}}</view>					</view>				</view>			</view>					</view>				<view class="title-list">			<view class="content">				<view class="list" v-for="(item1,index1) in bankList" :key="index1">					<template v-if="item1.type==1">						<view class="moduleItem" @click="clickModule(item1.majorId,index1)">							<view class="courseName">{{item1.name}}</view>							<view>								<image src="/static/icon/up.png" class="icon_up" v-if="!item1.showList"></image>								<image src="/static/icon/down.png" class="icon_up" v-if="item1.showList"></image>							</view>						</view>												<template v-if="item1.showList">							<view v-for="(item2,index2) in item1.list" :key="index2" >								<view class="section" @click="changeItem(index1,item2.chapterExamId,item1.type)">									<image src="/static/icon/up1.png" class="icon_up" v-if="!item2.showList"></image>									<image src="/static/icon/down1.png" class="icon_up" v-if="item2.showList"></image>									{{item2.name}}								</view>								<view  v-if="item2.showList">									<view class="article"  v-for="(article,index3) in item2.list" :key="index3">										<view class="flex-auto">											<view class="tit">{{article.examName}}</view>											<view class="desc">												<view class="flex-auto">													正确率													<text class="green">65%</text>												</view>												<view class="flex-auto">													已完成													<text class="blue">65%</text>												</view>											</view>										</view>										<navigator :url="'/pages2/bank/questionBankExplain?continue=1&recordId='+article.recordId+'&id='+article.examId+'&goodsid='+article.goodsId+'&moduleId='+article.moduleExamId+'&chapterId='+article.chapterExamId+''">											<view class="btn"  v-if="article.recordStatus == 0">继续</view>										</navigator>									</view>								</view>								<u-line></u-line>							</view>						</template>																	</template>										<template v-if="item1.type ==2">						<view class="section" @click="changeItem(index1,item1.majorId,item1.type)">							<image src="/static/icon/up1.png" class="icon_up" v-if="!item1.showList"></image>							<image src="/static/icon/down1.png" class="icon_up" v-if="item1.showList"></image>							{{item1.name}}						</view>						<view v-if="item1.showList" >							<view class="article" :key="index3" v-for="(article,index2) in item1.list">								<view class="flex-auto">									<view class="tit">{{article.name}}</view>									<view class="desc">										<view class="flex-auto">											正确率											<text class="green">65%</text>										</view>										<view class="flex-auto">											已完成											<text class="blue">65%</text>										</view>									</view>								</view>								<navigator :url="'/pages2/bank/questionBankExplain?continue=1&recordId='+article.recordId+'&id='+article.examId+'&goodsid='+article.goodsId+'&moduleId=0&chapterId='+article.chapterExamId+''">									<view class="btn" v-if="article.recordStatus == 0">继续</view>								</navigator>															</view>						</view>					</template>										<template v-if="item1.type ==3">						<view class="article" >							<view class="flex-auto">								<view class="tit">{{item1.name}}</view>								<view class="desc">									<view class="flex-auto">										正确率										<text class="green">65%</text>									</view>									<view class="flex-auto">										已完成										<text class="blue">65%</text>									</view>								</view>							</view>							<navigator :url="'/pages2/bank/questionBankExplain?continue=1&recordId='+item1.recordId+'&id='+item1.majorId+'&goodsid='+item1.goodsId+'&moduleId=0&chapterId=0'">								<view class="btn" v-if="item1.recordStatus == 0">继续</view>							</navigator>													</view>					</template>				</view>			</view>		</view>			</view></template><script>import { mapGetters } from 'vuex';export default {	data() {		return {			bankList:[],			goodsCount:{},			id:'',			context1:null,			context2:null,			caculateX:0,			caculateY:0,		};	},	onUnload() {			},	computed: { ...mapGetters(['userInfo']) },	onLoad(option) {		 this.id = option.id;		uni.getSystemInfo({			success:(res) => {				var winW = res.screenWidth;				var winH = res.screenHeight;				 uni.createSelectorQuery().in(this).select('.canvas').boundingClientRect().exec((newRes)=>{  					 					 this.goodsBankQuestionNum();						this.goodsBankDolist();					// this.goodsBankList();					 					  var width = newRes[0].width;					  var height = newRes[0].height;					  this.caculateX = winW/750;					  this.caculateY = winH/1334;					  var context1 = uni.createCanvasContext('Canvas1')					  this.context1 = context1;					  context1.setStrokeStyle("#EEEEEE")					  context1.setLineWidth(this.caculateX * 20)					  context1.arc(this.caculateX * 90, this.caculateX * 90, this.caculateX * 80, 0, 2 * Math.PI, true)					  context1.stroke()					  context1.draw()					  					  					  					  					  var context2 = uni.createCanvasContext('Canvas2')					  this.context2 = context2;					  context2.setStrokeStyle("#EEEEEE")					  context2.setLineWidth(this.caculateX * 20)					  context2.arc(this.caculateX * 90, this.caculateX * 90, this.caculateX * 80, 0, 2 * Math.PI, false)					  context2.stroke()					  context2.draw()				})  							}		})	},	onShow() {					},	methods: {		goodsBankDolist() {			this.$api.goodsBankDolist({				goodsId:this.id			}).then(res => {				console.log(res)				this.bankList = res.data.data;			})		},		goodsBankList() {			this.$api.goodsBankList({				goodsId:this.id			}).then(res => {				console.log(res)				this.bankList = res.data.data;			})		},		goodsBankQuestionNum(){			this.$api.goodsBankQuestionNum(this.id).then(res => {				this.goodsCount = res.data.data								this.context1.beginPath()				this.context1.setStrokeStyle("#32D74B")				this.context1.setFillStyle('#32D74B')				this.context1.setTextAlign('center')				this.context1.setLineCap('round')				this.context1.setFontSize(this.caculateX * 32)				this.context1.fillText((this.goodsCount.rightNum / this.goodsCount.totalNum * 100).toFixed(2)+'%', this.caculateX * 90, this.caculateX * 90, this.caculateX * 180)				this.context2.save()				this.context2.translate(this.caculateX * 90, this.caculateX * 90)				this.context2.rotate(-90 * Math.PI/180);				this.context1.arc(this.caculateX * 90, this.caculateX * 90, this.caculateX * 80, 0, (this.goodsCount.rightNum / this.goodsCount.totalNum) * 2 * Math.PI, false)				this.context2.restore()				this.context1.stroke()				this.context1.draw()								this.context2.beginPath()				this.context2.setStrokeStyle("#007AFF")				this.context2.setFillStyle("#007AFF")				this.context2.setTextAlign('center')				this.context2.setLineCap('round')				this.context2.setFontSize(this.caculateX * 32)				this.context2.fillText((this.goodsCount.doNum / this.goodsCount.totalNum * 100).toFixed(2)+'%', this.caculateX * 90, this.caculateX * 90, this.caculateX * 180)				this.context2.save()				this.context2.translate(this.caculateX * 90, this.caculateX * 90)				this.context2.rotate(-90 * Math.PI/180);				this.context2.arc(this.caculateX * 90, this.caculateX * 90, this.caculateX * 80, 0, (this.goodsCount.doNum / this.goodsCount.totalNum) * 2 * Math.PI, false)				this.context2.restore()				this.context2.stroke()				this.context2.draw()			})		},		clickModule(id,index) {									if(this.bankList[index].list) {				this.$set(this.bankList[index],'showList',!this.bankList[index].showList)				return;			}						this.$api.goodsChapterDolist({				moduleExamId:id			}).then(res => {				this.$set(this.bankList[index],'showList',true)				this.$set(this.bankList[index],'list',res.data.data)				 			})		},		changeItem(index1,id,type) {						if(type == 1) {				if(this.bankList[index1].list[index2].list) {					this.$set(this.bankList[index1].list[index2],'showList',!this.bankList[index1].list[index2].showList)					return;				}								this.$api.goodsExamList({					chapterExamId:id				}).then(res => {										this.$set(this.bankList[index1].list[index2],'showList',true)					this.$set(this.bankList[index1].list[index2],'list',res.data.data)										 				})							} else if(type == 2) {				if(this.bankList[index1].list) {					this.$set(this.bankList[index1],'showList',!this.bankList[index1].showList)					return;				}								this.$api.goodsExamDolist({					chapterExamId:id				}).then(res => {										this.$set(this.bankList[index1],'showList',true)					this.$set(this.bankList[index1],'list',res.data.data)										 				})			}											}	}};</script><style >	page{		background-color: #EAEEF1;	}</style><style lang="scss" scope>		.top {		margin:16rpx;		border-radius: 16rpx;		background:#fff;		padding:24rpx;		.title {			font-size: 24rpx;			line-height: 24rpx;			color: #333333;						text {				font-size: 30rpx;				color: #999999;			}		}				.circle-wrap {			margin-top:20rpx;						.circle-list {				display: flex;								.item {					flex:1;					padding-left:30rpx;										canvas {						margin:0 auto;						width:180rpx;						height:180rpx;					}										.text {						text-align: center;						margin-top:16rpx;						font-size: 24rpx;						color: #333333;					}				}				.numbers {					display: flex;					color:#999999;					font-size: 24rpx;					align-items: center;					justify-content: center;					flex-direction: column;										.blue {						margin-bottom:40rpx;						color: #007AFF;					}				}			}		}	}		.courseName{		white-space:nowrap;		overflow:hidden;		text-overflow:ellipsis; 	}			.moduleItem{		height: 80rpx;		color: #333333;		font-size: 32rpx;		line-height: 80rpx;		font-weight: bold;		display: flex;		justify-content: space-between;		}		.icon_up{		width: 32rpx;		height: 32rpx;	}		.title-list {		background: #EAEEF1;		padding:16rpx 16rpx 124rpx;		.content {						.list {				background:#fff;				margin-bottom:30rpx;				overflow: hidden;				border-radius: 16rpx;				padding:10rpx 16rpx;								.module {					font-size: 30rpx;					color: #333333;										.icon {						margin-right:10rpx;					}				}				 				.section {					font-size: 30rpx;					font-family: PingFang SC;					font-weight: bold;					color: #333333;					white-space:nowrap;					overflow:hidden;					text-overflow:ellipsis; 					margin: 20rpx 0;					display: flex;					align-items: center;				}								.article {					padding:14rpx 0 10rpx;					display: flex;					align-items: center;					margin-left:40rpx;					font-size: 24rpx;					color: #666666;					border-bottom: 1rpx solid #EEEEEE;										.flex-auto {						font-size: 26rpx;						flex:1;						margin-right:30rpx;																		&:nth-last-of-type(1) {							border:0;						}												.desc {							width: 480rpx;							padding:0 14rpx;							margin-top:20rpx;							height: 40rpx;							border: 1px solid #EEEEEE;							border-radius: 16rpx;							font-size: 26rpx;							display: flex;							align-items: center;														.blue {								font-size: 26rpx;								color:#007AFF;							}							.green {								font-size: 26rpx;								color:#32D74B;							}						}					}																.btn {						width: 96rpx;						height: 48rpx;						line-height: 48rpx;						text-align: center;						color:#fff;						font-size: 30rpx;						border-radius:24rpx;						background: #007AFF;						// margin-left:36rpx;						border-radius: 24rpx;					}				}			}		}	}			</style>
 |