「Mac畅玩鸿蒙与硬件29」UI互动应用篇6 - 多选问卷小应用

本篇将带你实现一个多选问卷小应用,用户可以勾选选项并点击提交按钮查看选择的结果。通过本教程,你将学习如何使用 Checkbox 组件、动态渲染列表、状态管理及用户交互,构建完整的应用程序。

在这里插入图片描述


关键词
  • UI互动应用
  • Checkbox 组件
  • 状态管理
  • 动态列表渲染
  • 用户交互

一、功能说明

本多选问卷小应用允许用户选择多个选项并点击“提交”按钮。提交后会显示用户选择的选项或提示未选择任何选项。这一示例展示了如何使用 Checkbox 组件管理用户选择,并动态显示内容。


二、所需组件
  • @Entry@Component 装饰器
  • ColumnRow 布局组件
  • Checkbox 组件用于用户选择
  • Button 组件用于提交
  • @State 修饰符用于状态管理
项目结构
  • 项目名称MultiSelectSurveyApp
  • 自定义组件名称SurveyPage
  • 代码文件SurveyPage.etsIndex.ets

三、代码实现
// 文件名:SurveyPage.ets// 定义问卷页面组件
@Component
export struct SurveyPage {// 问卷选项数组questions: string[] = ['选项1', '选项2', '选项3', '选项4'];// 状态数组,用于保存每个选项的选中状态@State selectedAnswers: boolean[] = [false, false, false, false];@State isSubmitted: boolean = false; // 用于指示是否已提交// 构建页面布局和组件build() {Column({ space: 20 }) { // 垂直布局容器,子组件间距为 20// 问卷标题Text('请选择你喜欢的选项:').fontSize(24).fontWeight(FontWeight.Bold).alignSelf(ItemAlign.Center);// 使用 ForEach 渲染多个复选框ForEach(this.questions, (question: string, index: number) => {Row() {Checkbox({ name: `checkbox${index}`, group: 'surveyGroup' }) // 创建复选框组件.select(this.selectedAnswers[index]) // 设置选中状态.selectedColor(Color.Blue) // 选中时的颜色.onChange((value: boolean) => { // 回调函数,更新选中状态this.selectedAnswers[index] = value;this.isSubmitted = false; // 每次改变选中状态时重置提交状态});Text(question) // 显示选项文本.fontSize(20).margin({ left: 10 });}});// 提交按钮Button('提交').onClick(() => {this.submitAnswers(); // 提交时触发的操作}).fontSize(20).backgroundColor(Color.Green).fontColor(Color.White).margin({ top: 20 });// 根据提交状态显示不同内容if (this.isSubmitted) {if (this.getSelectedOptions().length > 0) {Text(`你选择了: ${this.getSelectedOptions().join(', ')}`) // 显示选择结果.fontSize(18).fontColor(Color.Blue).margin({ top: 20 });} else {Text('未选择任何选项').fontSize(18).fontColor(Color.Red).margin({ top: 20 });}}}.padding(20).width('100%').height('100%').alignItems(HorizontalAlign.Center);}// 获取已选中的选项列表private getSelectedOptions(): string[] {return this.questions.filter((_, index) => this.selectedAnswers[index]);}// 提交答案的逻辑private submitAnswers() {this.isSubmitted = true; // 更新提交状态console.log('用户提交的答案:', this.getSelectedOptions()); // 在控制台输出选中的答案}
}
// 文件名:Index.ets// 导入自定义组件
import { SurveyPage } from './SurveyPage'// 定义应用入口组件
@Entry
@Component
struct Index {build() {Column() {SurveyPage() // 引用问卷页面组件}.padding(20) // 设置页面内边距}
}

效果示例:用户选择多个选项并点击“提交”按钮后,应用会在页面上显示用户的选择结果。

在这里插入图片描述


四、代码解读
  • @State selectedAnswers
    用于保存每个选项的选中状态,Checkbox 组件的选中与否根据此状态控制。
  • ForEach 循环
    用于动态生成 Checkbox 组件,方便渲染多项问卷选项。
  • getSelectedOptions() 方法
    返回选中的选项数组,供显示和后续处理。
  • isSubmitted 状态
    用于控制提交按钮点击后的显示效果,以便在页面上显示提交结果。

五、优化建议
  1. 样式调整:可以为 Checkbox 添加自定义样式,使界面更符合应用需求。
  2. 表单验证:在提交前验证用户是否选择了至少一个选项,避免无效提交。
  3. 交互反馈:提交后添加反馈提示,如“提交成功”或弹出确认框。
  4. 多语言支持:通过配置实现不同语言版本的问卷应用。

六、相关知识点
  • 「Mac畅玩鸿蒙与硬件14」鸿蒙UI组件篇4 - Toggle 和 Checkbox 组件
  • 「Mac畅玩鸿蒙与硬件11」鸿蒙UI组件篇1 - Text 和 Button 组件详解

小结

本篇教程通过多选问卷小应用的实现,演示了 Checkbox 组件的基本用法和状态管理。你学会了如何动态渲染选项并处理用户输入,为开发更复杂的交互应用打下了基础。


下一篇预告

下一篇「UI互动应用篇7 - 简易计步器」将展示如何实现一个简单的计步器应用,帮助用户记录每日步数并显示当前进度。


上一篇:「Mac畅玩鸿蒙与硬件28」UI互动应用篇5 - 滑动选择器实现
下一篇:「Mac畅玩鸿蒙与硬件30」UI互动应用篇7 - 简易计步器

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 并发编程学习笔记

参考资料: JAVA并发专题 - 终有救赎的专栏 - 掘金 Java并发编程学习路线(建议收藏��) | Java程序员进阶之路x沉默王二 面试题目: JUC第一讲:Java并发知识体系详解 面试题汇总(P6熟练 P7精通…

【Linux系统】—— 基本指令(二)

【Linux系统】—— 基本指令(二) 1 「alias」命令1.1 「ll」命令1.2 「alias」命令 2 「rmdir」指令与「rm」指令2.1 「rmdir」2.2 「rm」2.2.1 「rm」 删除普通文件2.2.2 「rm」 删除目录2.2.3 『 * 』 通配符 3 「man」 指令4 「cp」 指令4.1 拷贝普通…

Pytorch cuda版本选择(高效简洁版)

简而言之 Pytorch cuda版本选择 只需要低于cuda驱动版本即可,cuda驱动版本查看命令是nvidia-smi, nvcc -V 是runtimeapi版本可以不用管 1.只要看cuda驱动版本 安装pytorch 选择cuda版本,只要看你电脑cuda驱动版本即可。 2.选择依据 pytorch中cuda版本只…

Flink API 的层次结构

Apache Flink 提供了多层 API,每层 API 针对不同的抽象层次和用途,使得开发者可以根据具体需求选择合适的 API 层次。以下是 Flink API 的层次结构及其简要说明:

GPU集群上分布式训练大模型

总结一下如何在超算系统上进行预训练大模型的分布式训练 / 微调,文中代码已上传至 github 实验环境 集群1:国家广州超算 星逸A800智能AI集群 GPU:8 * Nvdia Tesla-A800 80G显存 CPU:2 * 28核 Intel Xeon Gold 6348 内存&#xff…

python爬虫自动库DrissionPage保存网页快照mhtml/pdf/全局截图/打印机另存pdf

目录 零一、保存网页快照的三种方法二、利用打印机保存pdf的方法 零 最近星球有人问如何使用页面打印功能,另存为pdf 一、保存网页快照的三种方法 解决方案已经放在星球内:https://articles.zsxq.com/id_55mr53xahr9a.html当然也可以看如下代码&…

Redis 中 Bitmap 原理和应用

Bitmap Redis中的Bitmap(位图)是一种较为特殊数据类型,它以最小单位bit来存储数据,我们知道一个字节由 8个 bit 组成,和传统数据结构用字节存储相比,这使得它在处理大量二值状态(true、false 或…

elementUI 点击弹出时间 date-picker

elementUI的日期组件,有完整的UI样式及弹窗,但是我的页面不要它的UI样式,点击的时候却要弹出类似的日期选择器,那怎么办呢? 以下是elementUI自带的UI风格,一定要一个输入框来触发。 这是我的项目中要用到的…

微软日志丢失事件敲响安全警钟

NEWS | 事件回顾 最近,全球最大的软件公司之一——微软,遭遇了一场罕见的日志丢失危机。据报告,从9月2日至9月19日,持续长达两周的时间里,微软的多项核心云服务,包括身份验证平台Microsoft Entra、安全信息…

2021-04-22 51单片机玩转点阵

理论就不赘述了,网络上多得很,直接从仿真软件感性上操作认识点阵,首先打开ISIS仿真软件,放置一个点阵和电源与地线就可以开始了;由点阵任何一脚连线到地线,另一边对应的引脚就连接到电源,如图:点击运行看是否点亮?看到蓝色与红色的点表示电源正常但是没有任何亮点,这时对调一下…

(十三)JavaWeb后端开发——MySQL2

目录 1.DQL数据查询语言 1.1基本查询 1.2条件查询 where关键字 1.3分组查询 1.4排序查询 1.5分页查询 2.多表设计 3.多表查询——联查 4.多表查询——子查询​ 5.MySQL 事务 6.事务管理(事务进阶) 7.MySQL 索引 1.DQL数据查询语言 分为五大…

恭喜!2024年度大连市科技人才创新、科技人才创业项目拟立项公示!

精选SCI/SSCI/EI SCI&EI ●IEEE 1区TOP 计算机类(含CCF); ●EI快刊:最快1周录用! 知网(CNKI)、谷歌学术期刊 ●7天录用-检索(100%录用),1周上线; 免费稿件评估 …

【前端】-音乐播放器(源代码和结构讲解,大家可以将自己喜欢的歌曲添加到数据当中,js实现页面动态显示音乐)

前言:音乐播放器是前端开发中的一个经典项目,通过它可以掌握很多核心技术,如音频处理、DOM操作、事件监听、动画效果等。这个项目不仅能提升前端开发的技能,还能让开发者深入理解JavaScript与HTML的协同作用。 页面展示&#xff1…

虚拟机linux7.9下安装mysql

1.MySQL官网下载安装包: MySQL :: Download MySQL Community Server https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz 2.解压文件: #tar xvzf mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz 3.移动文件&#…

03_CC2530基于定时器3的Delay_ms函数

CC2530定时器3与Delay_ms延时函数 前言 ​ Delay函数是开发中常用到的函数,可以用于按键消抖,LED闪烁,生成一定频率信号等(软件模拟通讯协议)。由于利用循环执行一定次数的空指令实现的延时函数在精度上并不能让人满意,而用定时…

【系统面试篇】其他相关题目——虚拟内存、局部性原理、分页、分块、页面置换算法

目录 一、相关问题 1. 什么是虚拟内存?为什么需要虚拟内存? (1)内存扩展 (2)内存隔离 (3)物理内存管理 (4)页面交换 (5)内存映…

43.第二阶段x86游戏实战2-提取游戏里面的lua

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 本人写的内容纯属胡编乱造,全都是合成造假,仅仅只是为了娱乐,请不要…

容器内pip安装Apache Airflow的经历:如何重置初始密码

背景 Apache Airflow™https://github.com/apache/airflow 是一个开源平台,用于开发、调度和监控面向批处理的工作流程。Airflow 可扩展的 Python 框架使您能够构建几乎可以连接任何技术的工作流程。Web 界面有助于管理工作流程的状态。Airflow 可以通过多种方式部…

Java爬虫 爬取某招聘网站招聘信息

Java爬虫 爬取某招聘网站招聘信息 一、系统介绍二、功能展示1.需求爬取的网站内容2.实现流程2.1数据采集2.2页面解析2.3数据存储 三、其它1.其他系统实现 一、系统介绍 系统主要功能:本项目爬取的XX招聘网站 二、功能展示 1.需求爬取的网站内容 2.实现流程 爬虫…

stm32不小心把SWD和JTAG都给关了,程序下载不进去,怎么办?

因为想用STM32F103的PA15引脚,调试程序的时候不小心把SWD和JTAD接口都给关了,先看下罪魁祸首 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//关掉JTAG,不关SWGPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, ENABLE);//关掉SW&am…