「Mac畅玩鸿蒙与硬件48」UI互动应用篇25 - 简易购物车功能实现

简介: 本篇教程将带你实现一个简易购物车功能。通过使用接口定义商品结构,我们将创建一个动态购物车,支持商品的添加、移除以及实时总价计算。

本篇教程将带你实现一个简易购物车功能。通过使用接口定义商品结构,我们将创建一个动态购物车,支持商品的添加、移除以及实时总价计算。

20241229_231240.gif


关键词
  • UI互动应用
  • 接口定义
  • 购物车功能
  • 动态计算
  • 商品管理
  • 列表操作

一、功能说明

简易购物车功能包含以下交互:

  1. 商品添加:将商品从商品列表添加到购物车。
  2. 商品移除:从购物车中移除指定商品。
  3. 动态总价计算:实时计算购物车内商品的总价。
  4. 列表展示:动态展示商品和购物车内容。

二、所需组件

  • @Entry@Component 装饰器
  • ListListItem 组件用于商品和购物车列表展示
  • RowColumn 布局组件
  • Text 组件用于展示商品信息和总价
  • Button 组件用于添加和移除商品
  • @State 修饰符用于状态管理

三、项目结构

  • 项目名称SimpleShoppingCart
  • 自定义组件名称ShoppingCartPage
  • 代码文件ProductInterface.etsShoppingCartPage.etsIndex.ets

四、代码实现

1. 定义商品接口
// 文件名:ProductInterface.ets

export interface Product {
   
  name: string; // 商品名称
  price: number; // 商品价格
}

2. 购物车页面代码
// 文件名:ShoppingCartPage.ets

import {
    Product } from './ProductInterface';

@Component
export struct ShoppingCartPage {
   
  @State cartItems: Product[] = []; // 购物车商品列表
  @State totalPrice: number = 0; // 总价
  private items: Product[] = this.loadProducts(); // 加载商品列表

  // 从接口加载商品
  loadProducts(): Product[] {
   
    return [
      {
    name: '苹果', price: 5 },
      {
    name: '橙子', price: 7 },
      {
    name: '香蕉', price: 3 },
    ];
  }

  // 添加商品到购物车
  addItem(item: Product): void {
   
    this.cartItems.push(item);
    this.updateTotalPrice();
  }

  // 从购物车移除商品
  removeItem(index: number): void {
   
    this.cartItems.splice(index, 1);
    this.updateTotalPrice();
  }

  // 更新总价
  updateTotalPrice(): void {
   
    this.totalPrice = this.cartItems.reduce((sum, item) => sum + item.price, 0);
  }

  build(): void {
   
    Column({
    space: 20 }) {
   
      Text('简易购物车')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .alignSelf(ItemAlign.Center);

      // 商品列表
      ForEach(this.items, (item: Product) => {
   
        Row({
    space: 10 }) {
   
          Text(`${
     item.name} - ¥${
     item.price}`)
            .fontSize(18);
          Button('添加商品')
            .onClick(() => this.addItem(item))
            .width(100);
        }
        .margin({
    top: 10 });
      });

      // 购物车展示
      Text('购物车')
        .fontSize(20)
        .margin({
    top: 20 });

      List({
    space: 10 }) {
   
        ForEach(this.cartItems, (item: Product, index) => {
   
          ListItem() {
   
            Row({
    space: 10 }) {
   
              Text(`${
     item.name} - ¥${
     item.price}`)
                .fontSize(18);
              Button('移除')
                .onClick(() => this.removeItem(index))
                .width(80);
            }
          }
        });
      }
      .width('100%');

      // 显示总价
      Text(`总价: ¥${
     this.totalPrice}`)
        .fontSize(20)
        .margin({
    top: 20 });
    }
    .padding(20)
    .width('100%')
    .height('100%');
  }
}

3. 主入口文件
// 文件名:Index.ets

import {
    ShoppingCartPage } from './ShoppingCartPage';

@Entry
@Component
struct Index {
   
  build() {
   
    Column() {
   
      ShoppingCartPage() // 调用购物车页面
    }
    .padding(20);
  }
}

效果示例:用户可以动态添加商品到购物车,移除商品,并实时查看购物车的总价。

效果展示
20241229_231240.gif


五、代码解读

  1. 商品接口定义

    • 使用 Product 接口定义商品的结构,包含 nameprice 两个属性。
  2. 商品列表展示

    • 使用 ForEach 遍历商品数组,动态生成商品名称和“添加商品”按钮。
  3. 购物车操作

    • addItem() 将商品添加到购物车数组,removeItem() 从购物车数组中删除商品。
  4. 动态总价计算

    • updateTotalPrice() 使用 reduce 函数动态计算购物车商品的总价。
  5. 状态管理

    • 使用 @State 修饰符管理购物车商品列表和总价,实现界面和数据的实时更新。

六、优化建议

  1. 添加商品搜索功能,便于用户快速查找商品。
  2. 支持商品数量调整,而非仅仅添加或移除。
  3. 提供总价折扣功能,提升用户体验。

七、效果展示

  • 动态商品添加与移除:用户可以灵活添加或移除商品。
  • 实时总价更新:购物车总价实时计算并显示。
  • 直观的界面布局:清晰展示商品列表和购物车内容。

八、相关知识点


小结

通过本篇教程,用户学会了通过接口定义商品结构,结合状态管理和列表操作,实现动态的购物车功能,为构建复杂的商品管理类应用打下基础。


下一篇预告

在下一篇「UI互动应用篇26 - 数字填色游戏」中,我们将学习如何实现一个互动式的数字填色小游戏,进一步提升用户界面的趣味性和互动性。


上一篇: 「Mac畅玩鸿蒙与硬件47」UI互动应用篇24 - 虚拟音乐控制台

下一篇: 「Mac畅玩鸿蒙与硬件49」UI互动应用篇26 - 数字填色游戏


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


目录
相关文章
|
9月前
HarmonyOS实战:Tab顶部滑动悬停功能实现
在鸿蒙开发中,实现Scroll嵌套List列表滑动时顶部悬停的效果是一个常见需求。本文详细介绍了如何通过布局和事件处理来实现这一功能。首先,使用Scroll嵌套List和Tab布局来构建基础页面。然后,通过设置nestedScroll属性为NestedScrollMode.PARENT_FIRST,确保外层Scroll优先滑动。接着,通过监听List和Scroll的滑动事件,处理滑动冲突,确保在特定条件下Scroll停止滑动,将滑动事件交给List处理。最终,实现了在上下滑动时优先让Scroll滑动的效果,并提供了扩展思路,如优先让List滑动等。
433 10
HarmonyOS实战:Tab顶部滑动悬停功能实现
|
9月前
|
定位技术 API
HarmonyOS实战:高德地图定位功能完整流程详解
本文详细介绍了在鸿蒙系统中使用高德地图实现完整定位功能的流程。首先分析需求,包括权限申请、检查GPS状态、单次或多次定位选择以及定位失败处理。接着通过代码实现具体步骤:添加定位权限、申请用户权限、检查GPS开关状态、启动定位服务,并处理定位成功或失败的情况。若定位失败,可尝试获取历史定位信息或使用默认位置。最后总结指出,虽然定位功能基础简单,但完整的流程与细节处理才是关键。建议读者动手实践,掌握高德地图定位功能的使用。
1262 15
|
5月前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
462 1
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
|
5月前
|
JavaScript 前端开发 开发者
鸿蒙应用开发从入门到实战(六):ArkTS声明式UI和组件化
鸿蒙开发语言ArkTS在继承了Typescrip语法的基础上,主要扩展了声明式UI开发相关的能力。
281 1
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
796 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
9月前
|
IDE API 开发工具
鸿蒙开发:DevEcoStudio中那些实用的小功能
本篇文章就暂时给大家盘点四个,在后续的文章中,关于DevEco Studio中能够提升我们开发效率的功能,也会不间断的进行总结。
236 12
鸿蒙开发:DevEcoStudio中那些实用的小功能
|
8月前
|
前端开发 容器
32.[HarmonyOS NEXT Row案例一(上)] 使用Row组件创建水平排列的功能按钮组
HarmonyOS NEXT提供了丰富的布局组件,其中Row组件是一种常用的水平布局容器,可以将子组件按照水平方向排列。本教程将详细讲解如何使用Row组件创建一个水平排列的功能按钮组,重点介绍基础间距与对齐的设置方法。
220 4
|
8月前
|
API 开发者
鸿蒙NEXT上传图片功能PhotoViewPicker核心功能解析
`PhotoViewPicker` 是鸿蒙系统中用于媒体资源选择的核心组件,通过它可以便捷地实现图片、视频等媒体文件的选择功能。下面从基本用法、参数配置到高级应用进行全面解析:
249 1
|
9月前
|
存储 安全 数据安全/隐私保护
HarmonyOS5云服务技术分享--匿名登录功能指南
本文为开发者详解如何实现应用的“游客模式”登录功能,让用户无需注册即可快速体验APP。通过5步集成指南(环境准备、初始化认证模块、智能登录检测、一键游客登录及账号升级策略),手把手教你完成开发流程。同时分享安全守则与高阶技巧,如敏感操作防护和事件监听等,帮助优化用户体验并提升留存率。文末更有小互动,期待你的观点交流!
|
9月前
|
JSON 数据格式
HarmonyOS实战: 城市选择功能的快速实现
本文详细介绍了在开发城市选择功能时,如何处理城市列表中的多音字、按字母顺序排列城市以及将首字母相同的城市分组的技术实现。首先,通过使用pinyin4js库处理多音字,确保每个城市名称的首字母正确。接着,利用Intl.Collator对城市数据进行字母排序。最后,通过遍历和条件判断,将首字母相同的城市分组,并使用ListItemGroup和sticky功能在UI中展示分组结果。文章强调了分组处理的复杂性,并鼓励读者动手实践以加深理解。
219 6