news 2026/5/26 7:21:33

鸿蒙5.0开发实战系列(一):黑马云音乐“猜你喜欢”列表布局实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
鸿蒙5.0开发实战系列(一):黑马云音乐“猜你喜欢”列表布局实现

鸿蒙5.0开发实战系列(一):黑马云音乐“猜你喜欢”列表布局实现

在鸿蒙5.0应用开发的学习过程中,页面布局是基础且核心的能力。本文将基于ArkTS技术,手把手带大家完成黑马云音乐“猜你喜欢”歌曲列表的布局开发,同时掌握鸿蒙开发中的多个关键组件与属性用法。

一、布局核心思路

在开始代码编写前,先明确鸿蒙页面布局的核心套路——先整体再局部,先布局再内容后美化

  • 先整体再局部:从最外层容器开始,由外到内分层搭建页面结构,避免一上来就陷入细节开发。
  • 先布局再内容后美化:先放置布局容器组件确定页面骨架,再填充文本、图片等内容组件,最后通过各类属性调整样式,让页面更美观。

二、整体容器与安全区配置

1. 外层容器搭建

页面整体内容为垂直排列,因此最外层选择column组件作为容器,同时设置宽高为100%,并配置背景色,让容器铺满整个屏幕:

Column(){// 后续内容将写在此处}.width('100%').height('100%').backgroundColor('#你的背景色值')

2. 安全区扩充

默认情况下,组件的背景色无法覆盖手机状态栏和底部导航栏的系统预留区域。此时可通过ExpandSafeArea属性扩充组件安全区,实现背景色全屏覆盖:

Column(){// 页面内容}// 其他属性....expandSafeArea({top:true,bottom:true})

三、标题“猜你喜欢”实现

column容器内添加text组件实现标题,具体配置如下:

  1. 文字与颜色:设置文字为“猜你喜欢”,并将字体颜色改为白色,避免与深色背景融合:fontColor('#FFFFFF')
  2. 左对齐处理:给text组件设置宽度100%,实现文字左对齐:.width('100%')
  3. 间距控制:给外层column添加左右内边距(如10),防止内容紧贴屏幕边缘;同时给标题text设置底部外边距(如10),预留与下方歌曲列表的间距。

核心代码示例:

Text('猜你喜欢').fontColor('#FFFFFF').width('100%').margin({bottom:10})

四、滚动歌曲列表实现

歌曲数量较多时需要支持滚动,鸿蒙中可通过list容器组件实现该效果,搭配listItem承载单首歌的布局。

1. 基础滚动结构

List(){ListItem(){// 单首歌布局内容}}// 关闭滚动条.scrollBar(BarState.Off)

若需要展示多首歌,可复制多个listItem,后续可结合数据实现动态渲染。

2. 单首歌横向布局容器

单首歌的封面、文字、更多按钮为横向排列,因此在listItem内使用row组件作为容器,并设置宽高和临时背景色辅助调试:

ListItem(){Row(){// 封面、文字、更多按钮内容}.width('100%').height(80)// 调试用背景色,完成后可删除.backgroundColor(Color.Pink)}

五、单首歌各区域布局实现

1. 左侧歌曲封面

使用image组件引入封面图,同时设置尺寸、圆角和间距:

Image($r('app.media.cover')).width(80).height(80)// 设置圆角.border({radius:8})// 与中间文字预留间距.margin({right:10})

2. 右侧更多图标

更多图标为SVG格式,可通过fillColor修改颜色,同时设置合适尺寸:

Image($r('app.media.more')).width(24).height(24).fillColor('#你的图标颜色值')

为让图标自动靠右,需给中间文字区域的容器添加layoutWeight(1),使其占据剩余空间,挤压图标到右侧。

3. 中间文字区域

中间文字包含歌名、VIP标识和歌手名,需嵌套columnrow组件实现:

  • 歌名:用text组件展示,设置白色、左对齐、加粗样式,并添加底部外边距:
Text('麝香夫人').fontColor('#FFFFFF').width('100%').fontWeight(FontWeight.Bold).margin({bottom:15})
  • VIP标识与歌手名:用row组件承载,给VIP标识添加边框、圆角和内边距,同时设置与歌手名的间距:
Row(){Text('VIP').fontColor('#金色值').border({width:1,color:'#金色值',radius:12}).padding({left:5,right:5,top:3,bottom:3}).margin({right:10})Text('凤凰传奇').fontColor('#浅灰色值')}.width('100%')

这是最终的结果,大家可以看一下

六、核心知识点总结

  1. list组件:用于实现滚动列表,搭配listItem承载列表项,通过scrollBar(BarState.Off)可关闭滚动条。
  2. layoutWeight属性:设置为1时,组件将占据外层容器的剩余空间,常用于实现“左右固定、中间自适应”的布局。
  3. ExpandSafeArea属性:可扩充组件安全区,让背景色等样式覆盖系统预留的状态栏和导航栏区域。

本文是鸿蒙5.0开发实战系列的第一篇,后续将继续分享鸿蒙应用开发的更多实战技巧与核心知识点,欢迎持续关注!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 20:10:28

Cmder终极美化指南:5分钟让Windows命令行颜值爆表

Cmder终极美化指南:5分钟让Windows命令行颜值爆表 【免费下载链接】cmder 项目地址: https://gitcode.com/gh_mirrors/cmd/cmder 厌倦了Windows默认的黑白命令行界面?想要一个既美观又实用的终端环境?Cmder作为Windows平台最受欢迎的…

作者头像 李华
网站建设 2026/5/25 19:42:42

VGGT如何重塑三维视觉:从单图理解到多视角重建的技术演进

VGGT如何重塑三维视觉:从单图理解到多视角重建的技术演进 【免费下载链接】vggt VGGT Visual Geometry Grounded Transformer 项目地址: https://gitcode.com/gh_mirrors/vg/vggt 视觉几何基础Transformer(VGGT)正在重新定义三维场景理…

作者头像 李华
网站建设 2026/5/26 5:55:59

mybatis入门案例及解释

2 示例12.1 创建2.1.1 创建项目新建Maven项目,然后直接下一步。展开三角填写信息,最后一行版本不填,直接用默认的。然后完成。进度条走完后,点文件,设置,展开编辑器,在点文件和代码模板。然后先…

作者头像 李华
网站建设 2026/5/26 5:54:46

【血压计算】基于matlab从光电容积脉搏波(PPG)和心电图(ECG)信号中提取的多种特征,推导血压测量值附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 🍊个人信条:格物致知,完整Matlab代码获取及仿…

作者头像 李华
网站建设 2026/5/26 2:19:59

学习记录(二十五)-Cursor的pro计划+云服务器使用常识

目录 前言 一、如何跳过Cursor的7天免费计划? 二、升级完成后,出现地区不匹配怎么办? 三、云服务器一些基本常识 总结 前言 感谢同学的资助,在我急需的时候让我用上了Cursor的pro版本。不过记录一下在充值和使用过程中遇到的…

作者头像 李华
网站建设 2026/5/26 5:54:51

代码克隆检测的挑战与AI的机遇

代码克隆检测是软件测试中的重要环节,涉及识别代码库中的相似或重复片段。传统方法如基于文本、令牌或抽象语法树(AST)的匹配,虽有一定效果,但常面临高误报率、难以检测语义克隆(功能相似但结构不同&#x…

作者头像 李华