HarmonyOS NEXT星河版之在线考试功能实战

2024-05-07 10:04

本文主要是介绍HarmonyOS NEXT星河版之在线考试功能实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、目标
    • 二、基础搭建
      • 2.1 定义数据
      • 2.2 mock数据
      • 2.3 主页面布局
        • 2.3.1 布局规划
        • 2.3.2 标题栏
        • 2.3.3 进度条
        • 2.3.4 答题模块
        • 2.3.5 底部按钮
      • 2.4 主页面逻辑
        • 2.4.1 加载数据及定义变量
        • 2.4.2 上一题、下一题
    • 三、选项点击及高亮
      • 3.1 声明对象及变量
      • 3.2 给选项注册点击事件
      • 3.3 处理背景和文本颜色
    • 四、小结

一、目标

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、基础搭建

2.1 定义数据

// 题目
export interface ExamItem {id: numbertitle: stringoptions: OptionItem[]
}
// 答案
export interface OptionItem {letter: stringcontent: string
}

2.2 mock数据

export const mockExamDataList: ExamItem[] = [{id: 1,title: 'Android系统的构建系统叫什么名字?',options: [{ letter: 'A', content: 'Gradle' },{ letter: 'B', content: 'Maven' },{ letter: 'C', content: 'Ant' },{ letter: 'D', content: 'Make' },],},{id: 2,title: '以下哪个组件不是Android架构的一部分?',options: [{ letter: 'A', content: 'Activity(活动)' },{ letter: 'B', content: 'Service(服务)' },{ letter: 'C', content: 'Content Provider(内容提供者)' },{ letter: 'D', content: 'Fragment(片段)' },],},{id: 3,title: 'Android中的RecyclerView控件有什么用途?',options: [{ letter: 'A', content: '显示一个可滚动的元素列表' },{ letter: 'B', content: '在不同活动之间导航' },{ letter: 'C', content: '播放视频内容' },{ letter: 'D', content: '绘制自定义的形状和路径' },],},
];

2.3 主页面布局

2.3.1 布局规划

将主页面布局抽取,封装对应如下:
在这里插入图片描述

2.3.2 标题栏
@Builder
getTitleBar() {Stack({ alignContent: Alignment.Start }) {Image($r('app.media.ic_left_arrow')).width(24)Text('在线考试').width('100%').textAlign(TextAlign.Center)}.padding({ left: 12, right: 12 }).width('100%').height(52).backgroundColor(Color.White).borderWidth({bottom: 0.5}).borderColor('#e5e5e5')
}
2.3.3 进度条
@Builder
getProgressView() {Row() {Progress({ value: this.currentIndex + 1, total: this.questionList.length }).padding({ left: 12, right: 12 })Text() {Span(`${this.currentIndex + 1}`).fontColor(Color.Black)Span('/' + this.questionList.length).fontColor(Color.Gray)}.layoutWeight(1)}.width('100%')
}
2.3.4 答题模块
Column() {Column({ space: 5 }) {Text(this.currentQuestion.title).margin({ bottom: 6, top: 12 })ForEach(this.currentQuestion.options, (item: OptionItem) => {Row() {Text(item.letter + '. ')Text(item.content)}.width('100%').height(40).padding({ left: 12 }).backgroundColor('#F9F9F9')})}.alignItems(HorizontalAlign.Start).width('100%').padding({ left: 15, right: 15 })}.layoutWeight(1)
2.3.5 底部按钮
@Builder
getBottomView() {Row() {Row({ space: 3 }) {Image($r('app.media.ic_arrow_left')).width(15).fillColor(this.getPreEnable() ? Color.Black : '#BABABA')Text('上一题').fontColor(this.getPreEnable() ? Color.Black : '#BABABA')}.onClick(() => {this.onPreClick()})Row({ space: 3 }) {Text('下一题').fontColor(this.getNextEnable() ? Color.Black : '#BABABA')Image($r('app.media.ic_arrow_right')).width(15).fillColor(this.getNextEnable() ? Color.Black : '#BABABA')}.onClick(() => {this.onNextClick()})}.width('100%').justifyContent(FlexAlign.SpaceBetween).backgroundColor(Color.White).height(50).padding({left: 12, right: 12}).border({color: '#e5e5e5',width: { top: 1 }})
}

2.4 主页面逻辑

2.4.1 加载数据及定义变量
// 题目列表@State questionList: ExamItem[] = []// 当前显示第N题@State currentIndex: number = 0// 当前题目@State currentQuestion: ExamItem = {} as ExamItemaboutToAppear(): void {this.loadData()}async loadData() {// 模拟网络获取数据this.questionList = await new Promise<ExamItem[]>((resolve, reject) => {setTimeout(() => {resolve(mockExamDataList)}, 500)});// 默认展示第一条this.currentQuestion = this.questionList[this.currentIndex]}
2.4.2 上一题、下一题
onPreClick() {if (this.getPreEnable()) {this.currentIndex--this.currentQuestion = this.questionList[this.currentIndex]}
}onNextClick() {if (this.getNextEnable()) {this.currentIndex++this.currentQuestion = this.questionList[this.currentIndex]}
}getPreEnable() {return this.currentIndex > 0
}getNextEnable() {return this.currentIndex < this.questionList.length - 1
}

三、选项点击及高亮

3.1 声明对象及变量

export interface UserAnswer {questionId: number // 问题IDuserAnswer: string // 用户选择项
}

在主页面中,定义变量,存储用户做题数据,如下:

// 存储题目和用户答案
@State userAnswerList: Record<number, UserAnswer> = {}

3.2 给选项注册点击事件

ForEach(this.currentQuestion.options, (item: OptionItem) => {Row() {Text(item.letter + '. ')Text(item.content)}.width('100%').height(40).padding({ left: 12 }).onClick(() => {this.onUserAnswerClick(item)})})

处理点击事件:

onUserAnswerClick(option: OptionItem) {this.userAnswerList[this.currentQuestion.id] = {questionId: this.currentQuestion.id,userAnswer: option.letter}}

3.3 处理背景和文本颜色

Row() {Text(item.letter + '. ').fontColor(this.getOptionColor(item, 'font'))Text(item.content).fontColor(this.getOptionColor(item, 'font'))
}
...
.backgroundColor(this.getOptionColor(item))
/*** 获取选择项背景或文本颜色* @param option 当前选择项* @param type 类型* @returns*/
getOptionColor(option: OptionItem, type: 'back' | 'font' = 'back') {if (this.currentQuestion) {const userAnswer = this.userAnswerList[this.currentQuestion.id]if (userAnswer?.userAnswer === option.letter) {return type === 'back' ? Color.Pink : Color.White}}return type === 'back' ? '#e5e5e5' : Color.Black
}

四、小结

  • UI布局
  • 题目切换处理
  • 做题标记及高亮展示

这篇关于HarmonyOS NEXT星河版之在线考试功能实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/967041

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3