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

相关文章

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML