OpenHarmony实战开发-城市选择案例、如何通过AlphabetIndexer实现首字母快速定位城市的索引条导航。

567 篇文章 5 订阅
555 篇文章 0 订阅

介绍

本示例介绍城市选择场景的使用:通过AlphabetIndexer实现首字母快速定位城市的索引条导航。

效果图预览

在这里插入图片描述
使用说明

分两个功能

  • 在搜索框中可以根据城市拼音模糊搜索出相近的城市,例如输入"a",会出现"阿尔山"、“阿勒泰地区”、“安庆”、“安阳”。
  • 下方城市列表通过AlphabetIndexer组件实现拼音索引条,通过滑动选择城市首拼,快速定位相关首拼城市。

实现思路

场景:通过AlphabetIndexer实现索引条导航

城市列表中的右侧首拼索引条,通过AlphabetIndexer组件实现首字母快速定位城市的索引条导航。

  • 通过AlphabetIndexer的selected属性与城市列表中List组件onScrollIndex事件绑定,CityView.ets
AlphabetIndexer({ arrayValue: TAB_VALUE, selected: this.stabIndex })
  .height('100%')
  .selectedColor($r('app.color.alphabet_select_color')) // 选中项文本颜色
  .popupColor($r('app.color.alphabet_pop_color')) // 弹出框文本颜色
  .selectedBackgroundColor($r('app.color.alphabet_selected_bgc')) // 选中项背景颜色
  .popupBackground($r('app.color.alphabet_pop_bgc')) // 弹出框背景颜色
  .popupPosition({ x: $r('app.integer.pop_position_x'), y: $r('app.integer.pop_position_y') })
  .usingPopup(true) // 是否显示弹出框
  .selectedFont({ size: $r('app.integer.select_font'), weight: FontWeight.Bolder }) // 选中项字体样式
  .popupFont({ size: $r('app.integer.pop_font'), weight: FontWeight.Bolder }) // 弹出框内容的字体样式
  .alignStyle(IndexerAlign.Right) // 弹出框在索引条左侧弹出
  .onSelect((tabIndex: number) => {
    this.scroller.scrollToIndex(tabIndex);
  })
  • 当用户滑动List组件,list组件onScrollIndex监听到firstIndex的改变,绑定赋值给AlphabetIndexer的selected属性,从而定位到字母索引。
  • 当点击AlphabetIndexer的字母索引时,通过scrollToIndex触发list组件滑动并指定firstIndex,从而实现List列表与AlphabetIndexer组件首字母联动吸顶展示,CityView.ets。
List({ space: 14, initialIndex: 0, scroller: this.scroller }) {
  .onScrollIndex((firstIndex: number, lastIndex: number) => {
     this.stabIndex = firstIndex;
  })
}

高性能知识点

由于需要通过搜索按钮频繁的控制自定义组件的显隐状态,CityView.ets,因此推荐使用显隐控制替代条件渲染,参考合理选择条件渲染和显隐控制文章。

工程结构&模块类型

citysearch                                      // har类型
|---src/main/ets/view
|   |---CitySearch.ets                          // 视图层-主页 
|   |---CityView.ets                            // 视图层-城市列表组件
|   |---SearchView.ets                          // 视图层-搜索组件
|---src/main/ets/model
|   |---DetailData.ets                          // 模型层-数据模块 

模块依赖

依赖har包-common库中UX标准

为了帮助大家更深入有效的学习到鸿蒙开发知识点,小编特意给大家准备了一份全套最新版的HarmonyOS NEXT学习资源,获取完整版方式请点击→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

HarmonyOS教学视频:语法ArkTS、TypeScript、ArkUI等…视频教程

在这里插入图片描述
在这里插入图片描述

鸿蒙生态应用开发白皮书V2.0PDF: 获取完整版白皮书方式请点击→https://docs.qq.com/doc/DZVVkRGRUd3pHSnFG?u=a42c4946d1514235863bb82a7b2ac128

在这里插入图片描述

鸿蒙 (Harmony OS)开发学习手册

一、入门必看→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.应用开发导读(ArkTS)
2………
在这里插入图片描述

二、HarmonyOS 概念→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.系统定义
2.技术架构
3.技术特性
4.系统安全
5.…在这里插入图片描述

三、如何快速入门?→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.基本概念
2.构建第一个ArkTS应用
3………在这里插入图片描述

四、开发基础知识→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
9.……在这里插入图片描述

五、基于ArkTS 开发→https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16.……在这里插入图片描述

更多了解更多鸿蒙开发的相关知识可以参考:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

  • 14
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iView Weapp的索引选择器组件提供了一个非常方便的方式来实现城市选择功能。你可以按照以下步骤来实现: 1. 引入索引选择器组件 ```javascript import iIndexList from '@/components/iViewweapp/dist/index-list/index-list'; import iIndexSection from '@/components/iViewweapp/dist/index-section/index-section'; ``` 2. 在页面中添加索引选择器组件 ```html <i-index-list :list="cityList" :section-style="sectionStyle" :index-style="indexStyle" @select="onSelect" @scroll="onScroll" > <i-index-section v-for="(item, index) in cityList" :key="index" :title="item.title" > <view v-for="(city, key) in item.children" :key="key">{{ city.name }}</view> </i-index-section> </i-index-list> ``` 3. 在页面的data中定义城市列表 ```javascript data() { return { cityList: [ { title: 'A', children: [ { name: '北京', code: '110000' }, { name: '安徽', code: '340000' }, { name: '澳门', code: '820000' }, ], }, { title: 'B', children: [ { name: '保定', code: '130600' }, { name: '包头', code: '150200' }, { name: '宝鸡', code: '610300' }, ], }, // ... ], sectionStyle: { backgroundColor: '#F2F3F5', color: '#666', }, indexStyle: { backgroundColor: '#F2F3F5', color: '#666', activeColor: '#333', }, }; }, ``` 4. 定义索引选择器的回调函数 ```javascript methods: { onSelect(item) { console.log('select', item); }, onScroll(event) { console.log('scroll', event); }, }, ``` 这样就可以实现一个简单的城市选择器了。当用户点击某个城市时,会触发onSelect回调函数,并传递该城市的信息。当用户滚动选择器时,会触发onScroll回调函数,并传递滚动事件的信息。你可以根据这些信息来实现你的业务逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值