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

news/2024/11/6 5:09:17 标签: macos, harmonyos, ui

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

在这里插入图片描述


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

一、功能说明

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


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

三、代码实现
// 文件名:SurveyPage.ets

// 定义问卷页面组件
@Component
export struct SurveyPage {
  // 问卷选项数组
  questions: uiltin">string[] = ['选项1', '选项2', '选项3', '选项4'];
  // 状态数组,用于保存每个选项的选中状态
  @State selectedAnswers: uiltin">boolean[] = [false, false, false, false];
  @State isSubmitted: uiltin">boolean = false; // 用于指示是否已提交

  // 构建页面布局和组件
  build() {
    Column({ space: 20 }) { // 垂直布局容器,子组件间距为 20
      // 问卷标题
      Text('请选择你喜欢的选项:')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .alignSelf(ItemAlign.Center);

      // 使用 ForEach 渲染多个复选框
      ForEach(this.questions, (question: uiltin">string, index: uiltin">number) => {
        Row() {
          Checkbox({ name: `checkbox${index}`, group: 'surveyGroup' }) // 创建复选框组件
            .select(this.selectedAnswers[index]) // 设置选中状态
            .selectedColor(Color.Blue) // 选中时的颜色
            .onChange((value: uiltin">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(): uiltin">string[] {
    return this.questions.filter((_, index) => this.selectedAnswers[index]);
  }

  // 提交答案的逻辑
  private submitAnswers() {
    this.isSubmitted = true; // 更新提交状态
    uiltin">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.niftyadmin.cn/n/5740217.html

相关文章

黄山谷捷:以创新为翼,领航新能源汽车散热基板行业

在竞争激烈的市场环境中,创新被视为企业发展的灵魂和生命线,是推动持续成长、保持竞争力的关键要素。作为专注于功率半导体模块散热基板研发、生产和销售的高新技术企业,黄山谷捷股份有限公司具有优秀的创新文化和基因,为公司的高…

前后端交互通用排序策略

目录 排序场景 排序实现思路 1. 静态代码排序实现 2.数据库驱动排序实现 3. 基于Java反射的动态排序实现 通用排序工具 SortListUtil 结语 排序场景 在面向前端数据展示的应用场景中,我们旨在实现一个更加灵活的排序机制,该机制能够支持对从后端传递…

大模型算法工程师经典面试题————Transformer中 前馈层(FFN) 的作用是什么?

什么是 前馈层(FFN)? Transformer的前馈层通常包含哪些组件? Transformer中 前馈层(FFN) 的作用是什么? 什么是 前馈层(FFN)? 前馈层(FFN)本质上就是一…

【LuatOS】修改LuatOS源码为PC模拟器添加高精度时间戳库timeplus

0x00 缘起 LuatOS以及Lua能够提供微秒或者毫秒的时间戳获取工具,但并没有提供获取纳秒的工具。通过编辑LuatOS源码以及相关BSP源码,添加能够获取纳秒的timeplus库并重新编译,以解决在64位Windows操作系统中LuatOS模拟器获取纳秒的问题&#…

51单片机教程(八)- 数码管的静态显示

1、项目分析 使用数码管显示指定的字符、数字和符号。 2、技术准备 1、显示器及其接口 单片机系统中常用的显示器有: 发光二极管LED(Light Emitting Diode)显示器、液晶LCD(Liquid Crystal Display)显示器、CRT显…

网络技术----wireshark抓包出现1500以上的大包原因分析

网络技术----wireshark抓包出现1500以上的大包原因分析 背景描述原因分析TSO(TCP segment offload,TSO)linux中关闭/开启TSO功能:其他类似TSO的机制 wireshark抓包来源 背景描述 我们在使用抓包工具的过程中,经常发现…

基于MATLAB的农业病虫害识别研究

1 背景介绍 病虫害一直是限制农业生产过程中农业和副产品的高质量和高产量的最重要因素。然而,在识别中国的病虫害时,无论是用肉眼识别的传统方法还是后来专家的系统判断,这些病虫害的特征一般都是主观因素。主观意图非常大,效率…

pdf添加目录标签python(手动配置)

先安装对应的库: pip install pypdf 代码分为两个部分,一部分是config.py,代码如下: offset=10 catgorys=[("第一章",12),("第二章",45), ] 需要自己手动更改offset,和目录列表 下面是主要代码: import pypdf # import sys from config import…