HarmonyOS NEXT应用元服务常见列表操作多类型列表项场景

场景描述

List组件作为整个首页长列表的容器,通过ListItem对不同模块进行视图界面定制,常用于门户首页、商城首页等多类型视图展示的列表信息流场景。

本场景以应用首页为例,将除页面顶部搜索框区域的其它内容,放在List组件内部,进行整体页面的构建。进入页面后,下滑刷新模拟网络请求;滑动页面列表内容,景区标题吸顶;滑动到页面底部,上滑模拟请求添加数据。

实现原理

根据列表内部各部分视图对应数据类型的区别,渲染不同的ListItem子组件。

Refresh组件可以进行页面下拉操作并显示刷新动效,List组件配合使用Swiper、Grid等基础组件用于页面的整体构建,再通过List组件的sticky属性、onReachEnd()事件和Refresh组件的onRefreshing()事件,实现下滑模拟刷新、上滑模拟添加数据及列表标题吸顶的效果。

开发步骤

顶部搜索框区域

复制代码
.Row() {
.  Text('Beijing')
.    // ...
.  TextInput({ placeholder: 'guess you want to search...'})
.    // ...
.  Text('more')
.    // ...
.}

HomePage.ets

实现效果:

  1. 在List的第一个ListItem分组中,使用Swiper组件构建页面轮播图内容。

    .List({ space: 12 }) {
    . // Swiper
    . ListItem() {
    . Swiper() {
    . ForEach(this.swiperContent, (item: SwiperType) => {
    . Stack({ alignContent: Alignment.BottomStart }) {
    . Image($r(item.pic))
    . }
    . }, (item: SwiperType) => JSON.stringify(item))
    . }
    . // ...
    . .autoPlay(true) // Set the sub-component to play automatically
    . .duration(1000) // Set the animation duration of the sub-component switchover
    . .curve(Curve.Linear) // Set the animation curve to uniform speed
    . .indicator( // Set the navigation point indicator
    . new DotIndicator()
    . .selectedColor(Color.White)
    . )
    . .itemSpace(10) // Set the space between sub-components
    . // ...
    . }
    . // ...
    .}

HomePage.ets

实现效果:

  1. 在List的第二个ListItem分组中,使用Grid组件构建页面网格区域。

    .List({ space: 12 }) {
    . // Swiper
    . ListItem() {
    . // ...
    . }
    . // Grid
    . ListItem() {
    . Grid() {
    . ForEach(this.gridTitle, (item: Resource) => {
    . GridItem() {
    . Column() {
    . Image($r('app.media.pic1'))
    . // ...
    . Text(item)
    . // ...
    . }
    . }
    . }, (item: Resource) => JSON.stringify(item))
    . }
    . .rowsGap(16) // Set the line spacing
    . .columnsGap(19) // Set the column spacing
    . .columnsTemplate('1fr 1fr 1fr 1fr 1fr') // Set the proportion of each column
    . // ...
    . }
    . // ...
    .}

HomePage.ets

实现效果:

  1. 推荐内容及列表内容的构建。

    .// Scenic spot list content details
    .@Builder
    .scenicSpotDetailBuilder(title: Resource) {
    . Column() {
    . Image(r('app.media.pic1')) . // ... . Column() { . Text(title) . // ... . Text() { . Span('Multi person group discount:') . // ... . Span('999¥') . // ... . } . .margin({ top: 4, bottom: 4 }) . . Text() { . Span('Multi person group discount:') . Span('1999¥') . } . // ... . } . // ... . } .} HomePage.ets .List({ space: 12 }) { . // Swiper . ListItem() { . // ... . } . // Grid . ListItem() { . // ... . } . // Customize display area. . ListItem() { . Row() { . Image(r('app.media.pic1'))
    . // ...
    . Image($r('app.media.pic1'))
    . // ...
    . }
    . // ...
    . }
    .
    . // Scenic spot classification list.
    . ForEach(this.scenicSpotTitle, (item: Resource) => {
    . ListItemGroup({ header: this.scenicSpotHeader(item) }) {
    . ForEach(this.scenicSpotArray, (scenicSpotItem: Resource) => {
    . ListItem() {
    . this.scenicSpotDetailBuilder(scenicSpotItem);
    . }
    . }, (scenicSpotItem: Resource) => JSON.stringify(scenicSpotItem))
    . }
    . .borderRadius(this.borderRadiusVal)
    . }, (item: Resource) => JSON.stringify(item))
    .
    . // ...
    .}

HomePage.ets

实现效果:

将构建好的页面内容,放在Refresh组件内部,并给List和Refresh组件添加对应的onReachEnd()和onRefreshing()回调,实现下拉模拟刷新和上滑添加列表数据的效果。

复制代码
.// Top search box.
.Row() {
.  // ...
.}
.// ...
.
.// Pull down refresh component.
.Refresh({ refreshing: $$this.isRefreshing }) {
.  // List as a long list layout.
.  List({ space: 12 }) {
.    // Swiper
.    ListItem() {
.      // ...
.    }
.    // Grid
.    ListItem() {
.      // ...
.    }
.    // Customize display area.
.    ListItem() {
.      // ...
.    }
.
.    // Scenic spot classification list.
.    ForEach(this.scenicSpotTitle, (item: Resource) => {
.      // ...
.    }, (item: Resource) => JSON.stringify(item))
.
.    // Customize bottom loading for more.
.    ListItem() {
.      Row() {
.        if (!this.noMoreData) {
.          LoadingProgress()
.            // ...
.        }
.        Text(this.noMoreData ? $r('app.string.no_more_data') : $r('app.string.loading_more'))
.      }
.      // ...
.    }
.    // ...
.  }
.  // ...
.  .onReachEnd(() => { // Callback triggered when the list is added to the end position
.    if (this.scenicSpotArray.length >= 20) {
.      // When the list data is greater than or equal to 20, noMoreData is set to true
.      this.noMoreData = true;
.      return;
.    }
.    setTimeout(() => {
.      this.scenicSpotArray.push('scenic area' + (this.scenicSpotArray.length + 1));
.    }, 500)
.  })
.}
.// Pull down refresh, simulate network request.
..onRefreshing(() => {
.  this.isRefreshing = true; // Enter the refresh state
.  setTimeout(() => {
.    // Set the landscapeSpotArray to the initial value
.    this.scenicSpotArray =
.      this.scenicSpotArray = ['scenic area 1', 'scenic area 2', 'scenic area 3', 'scenic area 4', 'scenic area 5'];
.    this.noMoreData = false;
.    this.isRefreshing = false;
.  }, 2000)
.})```

HomePage.ets

实现效果

本文主要引用整理于鸿蒙官方文档

相关推荐
takashi_void13 小时前
如何在本地部署大语言模型(Windows,Mac,Linux)三系统教程
linux·人工智能·windows·macos·语言模型·nlp
非凡ghost14 小时前
Typora(跨平台MarkDown编辑器) v1.12.2 中文绿色版
前端·windows·智能手机·编辑器·软件需求
十五年专注C++开发14 小时前
CFF Explorer: 一款Windows PE 文件分析的好工具
c++·windows·microsoft
Bruce_Liuxiaowei15 小时前
Windows系统错误6118全面解决方案:修复此工作组的服务器列表当前无法使用
运维·服务器·windows·网络安全
水饺编程17 小时前
第3章,[标签 Win32] :窗口类03,窗口过程函数字段
c语言·c++·windows·visual studio
一苓二肆17 小时前
代码加密技术
linux·windows·python·spring·eclipse
LinXunFeng17 小时前
如何舒适地沉浸式编程,这是我的答案
windows·程序员·mac
初听于你19 小时前
深入了解—揭秘计算机底层奥秘
windows·tcp/ip·计算机网络·面试·架构·电脑·vim
IoT小趴菜21 小时前
操作无法完成,因为磁盘管理控制台视图不是最新状态。请使用刷新任务刷新此视图。如果问题仍然存在,请关闭磁盘管理控制台,然后重新启动磁盘管理或重新启动计算机
windows·存储
x_feng_x1 天前
Java从入门到精通 - 集合框架(二)
java·开发语言·windows