用云开发搭建的微信答题小程序v1.0

简介: 用云开发搭建的微信答题小程序v1.0

近来百无聊赖,遂抽空做了一个答题小程序的系列教程,以及分享源码,是用云开发搭建的微信答题小程序v1.0。

界面截图
该答题小程序大致如下图:
image.png
微信小程序“防火安全知识专项学习与竞答”

结构层级
主要程序由3个界面组成,分别是index,test以及result,结构层级如下图所示:
image.png

index:包含开始答题界面的页面布局与样式,以及js逻辑;

test:包含答题界面的页面布局与样式,以及js逻辑;

results:包含答题成绩界面的页面布局与样式,以及js逻辑;

app:全局配置文件,全局变量等;

style:微信小程序的基本UI样式;

云开发数据库:存储相关题目数据。
image.png

1、index开始界面
主要功能是首页大图和信息的展示、按钮跳转以及分享。

(1)按钮跳转关键代码,就是catchtap点击事件与goToTest事件处理函数。
.wxml

<button class='cu-btn bg-red round block lg'>开始答题</button>


.js

//事件处理函数
goToTest: function() {

wx.navigateTo({
  url: '../test/test'
})

},
(2)分享实现,在button上使用open-type="share"属性,并且在页面js里面配置onShareAppMessage。
.wxml


.js

onShareAppMessage(res) {

return {
  title: '@你,快来参与消防安全知识答题活动吧~'
}

},
2、test答题界面
答题界面需要做的事情有:

与数据库连接,获取题目数据;

选中选项的前端交互;

点击切换到下一题;

系统自动判定答题结果,计算得分 ;

提交得分到数据库进行保存;

答题结束,跳转至答题成绩界面。

(1)与数据库连接,获取题目数据;
// 获取题库-函数定义
getQuestionList() {

// 显示 loading 提示框
wx.showLoading({
  title: '拼命加载中'
});
// 构建查询条件
activityQuestion.where({
  // 指定查询条件,返回带新查询条件的新的集合引用
  true: _.exists(true)
})
.get()
.then(res => {
  // 获取集合数据,或获取根据查询条件筛选后的集合数据。
  console.log('[云数据库] [activityQuestion] 查询成功')
  console.log(res.data)
  let data = res.data || [];
  
  // 将数据从逻辑层发送到视图层,通俗的说,也就是更新数据到页面展示
  this.setData({
    questionList:data,
    index: 0
  });

  // 隐藏 loading 提示框
  wx.hideLoading();
})

},
(2)选中选项的前端交互;
.wxml

  <label class="radio my-choosebox" wx:for="{{questionList[index].option}}" wx:for-index="key"  wx:for-item="value" wx:key="index">
    <radio value="{{key}}" checked="{{questionList[index].checked}}" />
    <text class="margin-left-xs">{{value}}</text>
  </label>
</radio-group>

.js

// 选中选项事件
radioChange(e){

this.data.chooseValue[this.data.index] = e.detail.value;

},
(3)点击切换到下一题;
.wxml


.js

// 下一题/提交 按钮
nextSubmit(){

// 如果没有选择
if (this.data.chooseValue[this.data.index] == undefined || this.data.chooseValue[this.data.index].length == 0) {  
  return wx.showToast({
    title: '请选择答案!',
    icon: 'none',
    duration: 2000
  })
}

// 判断所选择的选项是否为正确答案
this.chooseJudge();

// 判断是不是最后一题
this.lastJudge();

},
(4)系统自动判定答题结果,计算得分 ;
// 判断所选择的选项是否为正确答案
chooseJudge(){

var trueValue = this.data.questionList[this.data.index]['true'];
var chooseVal = this.data.chooseValue[this.data.index];
if (chooseVal.toString() != trueValue.toString()) {
  // 答错则记录错题
  this.data.wrong++;
  this.data.wrongListSort.push(this.data.index);
  this.data.wrongList.push(this.data.questionList[this.data.index]._id);
}else{
  // 答对则累计总分
  this.setData({
    totalScore: this.data.totalScore + 5
  })
}

},
(5)提交得分到数据库进行保存;
// 提交答卷
addExamRecord(){

wx.showLoading({
  title: '提交答卷中'
});
let examResult = {
  wrong: this.data.wrong,
  totalScore: this.data.totalScore
};
activityRecord.add({
  data: {
    ...examResult,
    createDate: db.serverDate()
  }
}).then(res => {

  // 跳转到答题结果页,查看成绩
  wx.redirectTo({
    url: '../results/results?id=' + res._id
  });

  wx.hideLoading();
})

}
(6)答题结束,跳转至答题成绩界面。
// 跳转到答题结果页,查看成绩
wx.redirectTo({

 url: '../results/results?id=' + res._id

});
3、results答题成绩界面
主要是查询答题情况和显示得分。在答题页面的时候,实现了提交得分到数据库进行保存。那么这里就可以从数据库中获取了。

.js

Page({
data: {

totalScore: null,
wrong: 0,
zql: null

},

onLoad(options) {

// 查看答题成绩
this.getExamResult(options.id);

},

// 系统自动判分
getExamResult(id){

wx.showLoading({
  title: '系统判分中'
});
activityRecord
.doc(id)
.get()
.then(res => {
  let examResult = res.data;
  
  let { wrong, totalScore } = examResult;
  this.setData({
    totalScore,
    wrong,
    zql: (20-wrong)/20*100
  })

  wx.hideLoading();
})

},
})
好了,用云开发搭建的微信答题小程序,v1.0版本至此完结,源码已经提交到gitee,撒花~

下一个版本v2.0正在在在开发中......

相关文章
|
6天前
|
小程序 前端开发 API
小程序全栈开发中的多端适配与响应式布局
【4月更文挑战第12天】本文探讨了小程序全栈开发中的多端适配与响应式布局。多端适配涉及平台和设备适应,确保统一用户体验;响应式布局利用媒体查询和弹性布局维持不同设备的布局一致性。实践中,开发者可借助跨平台框架实现多平台开发,运用响应式布局技术适应不同设备。同时,注意兼容性、性能优化和用户体验,以提升小程序质量和用户体验。通过这些方法,开发者能更好地掌握小程序全栈开发。
|
6天前
|
小程序 前端开发 API
微信小程序全栈开发中的异常处理与日志记录
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的异常处理和日志记录,强调其对确保应用稳定性和用户体验的重要性。异常处理涵盖前端(网络、页面跳转、用户输入、逻辑异常)和后端(数据库、API、业务逻辑)方面;日志记录则关注关键操作和异常情况的追踪。实践中,前端可利用try-catch处理异常,后端借助日志框架记录异常,同时采用集中式日志管理工具提升分析效率。开发者应注意安全性、性能和团队协作,以优化异常处理与日志记录流程。
|
6天前
|
小程序 安全 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的身份认证与授权机制。身份认证包括手机号验证、微信登录和第三方登录,而授权机制涉及角色权限控制、ACL和OAuth 2.0。实践中,开发者可利用微信登录获取用户信息,集成第三方登录,以及实施角色和ACL进行权限控制。注意点包括安全性、用户体验和合规性,以保障小程序的安全运行和良好体验。通过这些方法,开发者能有效掌握小程序全栈开发技术。
|
6天前
|
小程序 前端开发 安全
小程序全栈开发中的跨域问题及其解决方案
【4月更文挑战第12天】本文探讨了小程序全栈开发中的跨域问题及其解决方案。跨域问题源于浏览器安全策略,主要体现在前后端分离、第三方服务集成和数据共享上。为解决此问题,开发者可采用CORS、JSONP、代理服务器、数据交换格式和域名策略等方法。实践中需注意安全性、兼容性和性能。通过掌握这些解决方案,开发者能更好地处理小程序的跨域问题,提升用户体验。
|
6天前
|
JavaScript 前端开发 小程序
微信小程序全栈开发之性能优化策略
【4月更文挑战第12天】本文探讨了微信小程序全栈开发的性能优化策略,包括前端的资源和渲染优化,如图片压缩、虚拟DOM、代码分割;后端的数据库和API优化,如索引创建、缓存使用、RESTful API设计;以及服务器的负载均衡和CDN加速。通过这些方法,开发者可提升小程序性能,优化用户体验,增强商业价值。
|
6天前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中PWA技术的应用,PWA结合Web的开放性和原生应用的性能,提供离线访问、后台运行、桌面图标和原生体验。开发者可利用Service Worker实现离线访问,Worker处理后台运行,Web App Manifest添加桌面图标,CSS和JavaScript提升原生体验。实践中需注意兼容性、性能优化和用户体验。PWA技术能提升小程序的性能和用户体验,助力开发者打造优质小程序。
|
6天前
|
SQL 安全 小程序
探索微信小程序全栈开发的安全性问题
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的安全性问题,包括数据安全、接口安全、隐私保护和代码安全。为解决这些问题,建议采取数据加密、使用HTTPS协议、身份认证与授权、输入验证、安全审计及漏洞扫描以及安全培训等措施。通过这些方法,开发者可提升小程序安全性,保护用户隐私和数据。
|
6天前
|
小程序 前端开发 JavaScript
小程序全栈开发:前端与后端的完美结合
【4月更文挑战第12天】本文介绍了小程序全栈开发,涵盖前端和后端的关键点。前端使用WXML和WXSS进行页面结构和样式设计,JavaScript处理逻辑及组件使用;后端采用Node.js等语言处理业务逻辑、数据库设计和API接口开发。前端与后端通过数据交互实现结合,采用前后端分离模式,支持跨平台运行。调试测试后,提交微信审核并上线运营。掌握前端后端结合是小程序成功的关键。
|
1月前
|
小程序 API
点餐小程序实战教程09-订单功能开发
点餐小程序实战教程09-订单功能开发
|
1月前
|
小程序 UED
人力资源小程序的设计与开发步骤
人力资源小程序的设计与开发步骤
19 1