百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

鸿蒙Next仓颉语言开发实战教程:订单列表

ztj100 2025-07-10 22:14 5 浏览 0 评论

大家上午好,最近不断有友友反馈仓颉语言和ArkTs很像,所以要注意不要混淆。今天要分享的是仓颉语言开发商城应用的订单列表页。

首先来分析一下这个页面,它分为三大部分,分别是导航栏、订单类型和订单列表部分。

导航栏由返回按钮和搜索框组成,这里要注意组件横向占满屏幕时要使用layoutWeight属性,导航栏部分的实现代码如下:

Row(8) {
    Image(@r(app.media.back))
    .width(22)
    .height(22)
    .onClick({evet => Router.back()})
    Search(placeholder: "搜索").height(38).layoutWeight(1)
        .onClick({evet => })
}
.width(100.percent)
.height(60)
.padding(right: 12, left: 12)
.alignItems(VerticalAlign.Center)

订单类型应该是一个滚动的横条,虽然它现在没有占满整个屏幕,但是为了适配更多尺寸和类型的屏幕,我们还是要使用Scroll。里面的内容使用foreach循环添加,大家要慢慢习惯仓颉中Foreach的写法,另外这里定一个变量orderIndex和指定当前选中的订单类型,这一部分的具体实现代码如下:

Scroll{
    Row(25){
    ForEach(this.orderTypeList, itemGeneratorFunc: {item:String,index:Int64 =>
                if(this.orderIndex == index){
                     Text(item)
                     .fontColor(Color(215, 68, 62, alpha: 1.0))
                     .fontSize(17)
                     .fontWeight(FontWeight.Bold)
                }else {
                 Text(item)
                 .fontColor(Color.GRAY)
                 .fontSize(16)
                .onClick({evet => this.orderIndex = index})
                }
            })
}
.width(100.percent)
.height(40)
}
.height(40)
.padding( right: 12, left: 12)
.scrollable(ScrollDirection.Horizontal)
.scrollBar(BarState.Off)
.scrollBarColor(Color.GRAY)
.scrollBarWidth(50.px)

最后是订单列表部分,很明显是一个List组件,依然使用layoutWeight占满剩余屏幕。然后店铺名字和发货状态部分使用List的header来实现,

@Builder func itemHead(text:String) {
    Row{
        Row{
        Text(text)
        .fontSize(15)
        .fontWeight(FontWeight.Bold)
        .backgroundColor(Color.WHITE)
          Image(@r(app.media.righticon))
            .height(18)
            .width(18)
            .objectFit(ImageFit.Contain)
        }
        Text('卖家已发货')
        .fontColor(Color.RED)
        .fontSize(14)
    }
    .width(100.percent)
    .height(35)
    .justifyContent(FlexAlign.SpaceBetween)
    .alignItems(VerticalAlign.Center)
    .padding(left:12,right:12)
}

List{
     ListItemGroup(ListItemGroupParams(header:{=>bind(this.itemHead,this)('幽蓝旗舰店')})){

     }
}

订单商品部分虽然看起来较为复杂,反而不是很难,只要仔细分析布局和对齐方式就能轻松实现,具体代码如下:

ListItem{
    Column(10){
        Row(8){
            Image(@r(app.media.chaofu))
            .width(90)
            .height(90)
            
            Column(11){
                Row{
                    Text('牛津纺布通勤男士衬衫')
                    .fontSize(16)
                    .fontColor(Color.BLACK)
                    Text('yen27.9')
                    .fontSize(16)
                    .fontColor(Color.BLACK)
                }
                .justifyContent(FlexAlign.SpaceBetween)
                .width(100.percent)
                 Text('天蓝色,XL(180)')
                .fontSize(14)
                .fontColor(Color.GRAY)
                .padding(4)
                .backgroundColor(Color(241, 241, 241, alpha: 1.0))
                .borderRadius(4)
            }
            .height(90)
            .layoutWeight(1)
            .alignItems(HorizontalAlign.Start)
            .justifyContent(FlexAlign.Start)
            .padding(top:10)
        }
         Row(10){
            Text('实付款:')
            .fontSize(13)
            .fontColor(Color(74, 74, 74, alpha: 1.0))
            Text('yen27.9')
            .fontSize(16)
            .fontColor(Color.BLACK)
             .fontWeight(FontWeight.Bold)
         }
        .width(100.percent)
        .justifyContent(FlexAlign.End)
        Row(10){
            Text('延长收货')
            .padding(top:6,bottom:6,left:8,right:8)
            .backgroundColor(Color(240, 240, 240, alpha: 1.0))
            .fontSize(14)
            .fontColor(Color(74, 74, 74, alpha: 1.0))
            .borderRadius(6)
            Text('查看物流')
            .padding(top:6,bottom:6,left:8,right:8)
            .fontSize(14)
            .fontColor(Color(74, 74, 74, alpha: 1.0))
            .backgroundColor(Color(240, 240, 240, alpha: 1.0))
            .borderRadius(6)
            Text('确认收货')
            .padding(top:6,bottom:6,left:8,right:8)
            .fontSize(14)
            .fontColor(Color(74, 74, 74, alpha: 1.0))
            .backgroundColor(Color(240, 240, 240, alpha: 1.0))
            .borderRadius(6)
        }
        .width(100.percent)
        .justifyContent(FlexAlign.End)
    }
    .padding(left:12,right:12)
}

以上就是今天的内容分享,感谢阅读。##HarmonyOS语言##仓颉##购物#

相关推荐

Sublime Text 4 稳定版 Build 4113 发布

IT之家7月18日消息知名编辑器SublimeText4近日发布了Build4113版本,是SublimeText4的第二个稳定版。IT之家了解到,SublimeTe...

【小白课程】openKylin便签贴的设计与实现

openKylin便签贴作为侧边栏的一个小插件,提供便捷的文本记录和灵活的页面展示。openKylin便签贴分为两个部分:便签列表...

“告别 Neovim!为什么我投奔了刚开源的 Zed 编辑器?”

...

壹啦罐罐 Android 手机里的 Xposed 都装了啥

这是少数派推出的系列专题,叫做「我的手机里都装了啥」。这个系列将邀请到不同的玩家,从他们各自的角度介绍手机中最爱的或是日常使用最频繁的App。文章将以「每周一篇」的频率更新,内容范围会包括iOS、...

电气自动化专业词汇中英文对照表(电气自动化专业英语单词)

专业词汇中英文对照表...

Python界面设计Tkinter模块的核心组件

我们使用一个模块,我们要熟悉这个模块的主要元件。如我们设计一个窗口,我们可以用Tk()来完成创建;一些交互元素,按钮、标签、编辑框用到控件;怎么去布局你的界面,我们可以用到pack()、grid()...

以色列发现“死海古卷”新残片(死海古卷是真的吗)

编译|陈家琦据艺术新闻网(artnews.com)报道,3月16日,以色列考古学家发现了死海古卷(DeadSeaScrolls)新残片。新出土的羊皮纸残片中包括以希腊文书写的《十二先知书》段落,这...

鸿蒙Next仓颉语言开发实战教程:订单列表

大家上午好,最近不断有友友反馈仓颉语言和ArkTs很像,所以要注意不要混淆。今天要分享的是仓颉语言开发商城应用的订单列表页。首先来分析一下这个页面,它分为三大部分,分别是导航栏、订单类型和订单列表部分...

哪些模块可以用在 Xposed for Lollipop 上?Xposed 模块兼容性解答

虽然已经有了XposedforLollipop的安装教程,但由于其还处在alpha阶段,一些Xposed模块能不能依赖其正常工作还未可知。为了解决大家对于模块兼容性的疑惑,笔者尽可能多...

利用 Fluid 自制 Mac 版 Overcast 应用

我喜爱收听播客,健身、上/下班途中,工作中,甚至是忙着做家务时。大多数情况下我会用MarcoArment开发的Overcast(Freemium)在iPhone上收听,这是我目前最喜爱的Po...

Avalonia日志组件实现与优化指南(ar日志表扣)

...

浅色Al云食堂APP代码(三)(手机云食堂)

以下是进一步优化完善后的浅色AI云食堂APP完整代码,新增了数据可视化、用户反馈、智能推荐等功能,并优化了代码结构和性能。项目结构...

实战PyQt5: 121-使用QImage实现一个看图应用

QImage简介QImage类提供了独立于硬件的图像表示形式,该图像表示形式可以直接访问像素数据,并且可以用作绘制设备。QImage是QPaintDevice子类,因此可以使用QPainter直接在图...

滚动条隐藏及美化(滚动条隐藏但是可以滚动)

1、滚动条隐藏背景/场景:在移动端,滑动的时候,会显示默认滚动条,如图1://隐藏代码:/*隐藏滚轮*/.ul-scrool-box::-webkit-scrollbar,.ul-scrool...

浅色AI云食堂APP完整代码(二)(ai 食堂)

以下是整合后的浅色AI云食堂APP完整代码,包含后端核心功能、前端界面以及优化增强功能。项目采用Django框架开发,支持库存管理、订单处理、财务管理等核心功能,并包含库存预警、数据导出、权限管理等增...

取消回复欢迎 发表评论: