当前位置: 首页 > ai >正文

鸿蒙仓颉开发语言实战教程:实现商城应用首页

经过了几天的入门教程,我们终于进入到了仓颉开发语言的实战环节,今天分享的内容是实现商城应用的首页页面,效果图如下:

首页的内容包括导航栏、轮播图、商品分类和商品列表,我们下面逐一介绍。

导航栏

仓颉语言中是没有导航栏组件的,我们需要自己去开发。此处的导航栏也比较简单,只有一个搜索框,仓颉中的常见组件我们已经在之前的文章中做了讲解。所以这里就直接Row容器下添加Search组件:

Row {Search(placeholder: "搜索",  controller: this.searchController).height(38)
}.width(100.percent).height(60).padding(right: 12, left: 12)

轮播图

仓颉是有轮播图组件的,用法也比较简单:

Swiper{Image(@r(app.media.banner1)).width(100.percent).height(100.percent)Image(@r(app.media.banner2)).width(100.percent).height(100.percent)Image(@r(app.media.banner3)).width(100.percent).height(100.percent)
}.width(100.percent).height(160).duration(1500).autoPlay(true)

商品分类

这里我们会遇到仓颉的第一个复杂容器Grid,作用和ArkTs中的Grid一样:

Grid {ForEach(goodsTypeList,itemGeneratorFunc: {item: TypeItem, index: Int64 => GridItem {Column(){Image(item.getImage()).width(40).height(40).margin(bottom: 4)Text(item.getTitle()).fontSize(13).textAlign(TextAlign.Center).fontWeight(FontWeight.W400).margin(top:5)}}})}.columnsTemplate('1fr 1fr 1fr 1fr').rowsTemplate('1fr 1fr').width(100.percent).height(150).backgroundColor(0xFFFFFF)

商品列表

商品列表和分类几乎一样,只不过由4列改为2列:

Grid {ForEach(goodsList,itemGeneratorFunc: {item: GoodsItem, index: Int64 => GridItem {Column(){Image(item.getImage()).width(100.percent).height(200).margin(bottom: 4)Text(item.getTitle()).fontSize(14).textAlign(TextAlign.Start).fontWeight(FontWeight.W400)Text(item.getPrice()).fontSize(12).textAlign(TextAlign.Center).fontWeight(FontWeight.W400).fontColor(Color.RED)}.alignItems(HorizontalAlign.Start)}})}.columnsTemplate('1fr 1fr').columnsGap(10).rowsGap(10).width(100.percent).backgroundColor(0xFFFFFF).padding( right: 10, left: 10)

最后要注意,除导航栏外,其他组件是需要可以滚动的,所以需要把它们放到List组件中,注意List的属性设置,这里使用layoutWeight来自动分配空间:

List() {//bannerListItem {}    //分类ListItem {}//商品ListItem {}
}.layoutWeight(1)

源码已经上传到gitee,大家需要的话可以下载:

https://gitee.com/the-blue-plan/cjshop

#HarmonyOS语言##仓颉##购物#

http://www.xdnf.cn/news/7965.html

相关文章:

  • 尼科彻斯定理
  • Vue 3.0中自定义指令
  • 01-jenkins学习之旅-window-下载-安装
  • 【云原生安全】零信任与机密计算
  • Qt C++实现马的遍历问题
  • 【JavaEE】(1) 计算机如何工作
  • 阿里巴巴 MCP 分布式落地实践:快速转换 HSF 到 MCP server
  • 记录:uniapp 上线部署到微信小程序vendorjs包过大的问题
  • 外网如何连接内网中的mysql数据库服务器?简单网络工具方案
  • Cause: org.apache.ibatis.ognl.OgnlException: sqlSegment
  • 【C++】位图+布隆过滤器
  • JAVA EE(进阶)_CSS
  • 如何排查服务器 CPU 温度过高的问题并解决?
  • C++ 前缀和数组
  • C++STL(二)类模板
  • YCKC【二分查找专题】题解
  • 《对话记忆的进化史:智能体大模型如何实现跨轮次的深度交互》
  • 国酒华夏实业酒水供应链:全品类覆盖打造一站式购销平台
  • 第四十三节:人脸检测与识别-人脸识别基础 (Eigenfaces, Fisherfaces, LBPH)
  • Selenium自动化测试终极指南:从原理到实战
  • 【Python生成器全解析】从基础到高阶应用实战
  • C语言—Linux环境下CMake设置库(动态/静态)
  • 借助IEDA ,Git版本管理工具快速入门
  • 多线程(七)
  • 开疆智能Profinet转RS485网关连接工业型土壤水分温度传感器 配置案例
  • 如何在 Windows 10 或 11 上安装 Adminer?
  • 非欧空间计算加速:图神经网络与微分几何计算的GPU优化(流形数据的内存布局优化策略)
  • MEMO数据DID与ZK技术:赋能RWA代币化与可信流通的新基石
  • BI 大屏是什么意思?具体应用在哪些方面?
  • 全球气体压力调节器市场深度洞察:技术演进、区域竞争与可持续发展路径(2025-2031)