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

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

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

20241105_003038.gif


关键词
  • 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) // 设置页面内边距
  }
}

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

20241105_003038.gif


四、代码解读

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

五、优化建议

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

六、相关知识点


小结

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


下一篇预告

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


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

下一篇: 「Mac畅玩鸿蒙与硬件30」UI互动应用篇7 - 简易计步器


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=286
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
1月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
182 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
26天前
|
存储 人工智能 编译器
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
52 10
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
|
4天前
|
开发框架 缓存 自然语言处理
HarmonyOS ArkTS声明式UI开发实战教程
本文深入探讨了ArkTS作为HarmonyOS生态中新一代声明式UI开发框架的优势与应用。首先对比了声明式与命令式开发的区别,展示了ArkTS如何通过直观高效的代码提升可维护性。接着分析了其核心三要素:数据驱动、组件化和状态管理,并通过具体案例解析布局体系、交互组件开发技巧及复杂状态管理方案。最后,通过构建完整TODO应用实战,结合调试优化指南,帮助开发者掌握声明式UI设计精髓,感受ArkTS的独特魅力。文章鼓励读者通过“破坏性实验”建立声明式编程思维,共同推动HarmonyOS生态发展。
33 3
|
4天前
|
存储 开发者
HarmonyOS NEXT 实战系列07-应用状态
AppStorage 是应用全局的 UI 状态存储,支持跨 Ability 数据共享,提供 `setOrCreate` 和 `get` 方法管理全局状态,并通过 `@StorageProp` 和 `@StorageLink` 实现单向或双向数据同步至组件。PersistentStorage 基于 AppStorage,提供状态变量的持久化能力,可将选定属性保存到设备磁盘,但写操作同步执行,建议持久化数据小于 2KB,以避免影响 UI 渲染性能。相关持久化文件位于 `/data/app/el2/.../persistent_storage` 目录下。
|
2月前
|
人工智能 自然语言处理 API
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
UI-TARS Desktop 是一款基于视觉语言模型的 GUI 代理应用,支持通过自然语言控制电脑操作,提供跨平台支持、实时反馈和精准的鼠标键盘控制。
745 17
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
|
24天前
|
开发框架 监控 JavaScript
解锁鸿蒙装饰器:应用、原理与优势全解析
ArkTS提供了多维度的状态管理机制。在UI开发框架中,与UI相关联的数据可以在组件内使用,也可以在不同组件层级间传递,比如父子组件之间、爷孙组件之间,还可以在应用全局范围内传递或跨设备传递。
47 2
|
16天前
|
Android开发 UED iOS开发
Harmony os next~UI开发与ArkUI框架
鸿蒙OS的UI开发基于ArkUI框架,采用声明式编程,简化开发流程。五大核心组件(Text、Button、List、Grid、Flex)助力高效布局,支持数据绑定与动态更新。事件响应机制灵敏,适合构建交互丰富的应用。实战技巧包括规范命名、样式复用和调试方法。掌握这些,轻松开发鸿蒙应用。下期预告:分布式开发,记得带上烤冷面!
27 0
|
19天前
|
传感器 人工智能 搜索推荐
探索HarmonyOS在智慧出行领域的AI类目标签应用
在科技飞速发展的今天,智慧出行成为交通领域的重要发展方向。HarmonyOS凭借强大的系统能力,为智慧出行注入新活力,特别是在AI类目标签技术的应用上。通过精准分类和标签化处理车辆、路况及出行者数据,AI类目标签技术提升了出行体验与交通管理效率。HarmonyOS的分布式软总线技术和隐私保护机制,确保了设备间的无缝连接与数据安全。实际应用中,该技术助力智能交通管理和个性化出行服务,为解决交通拥堵、优化资源配置提供了新思路。开发者也迎来了广阔的机遇与挑战,共同推动智慧出行的美好未来。
|
2月前
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
91 13
|
2月前
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
79 10