鴻蒙(Harmony) NEXT - AlphabetIndexer實現聯繫人字母索引

来源:https://www.cnblogs.com/yishaochu/p/18348668
-Advertisement-
Play Games

鴻蒙(Harmony) NEXT 9月份就要正式上架了,並且不會再相容安卓平臺,於是我也趕緊給App開發鴻蒙版本,接下來會寫一系列的Harmony開發教程。 今天使用AlphabetIndexer實現聯繫人字母索引,AlphabetIndexer是官方封裝好的組件 咱們實現後的效果圖: 代碼實現 首 ...


鴻蒙(Harmony) NEXT 9月份就要正式上架了,並且不會再相容安卓平臺,於是我也趕緊給App開發鴻蒙版本,接下來會寫一系列的Harmony開發教程。

今天使用AlphabetIndexer實現聯繫人字母索引,AlphabetIndexer是官方封裝好的組件

咱們實現後的效果圖:

代碼實現

首先在aboutToAppear方法中初始化數據,aboutToAppear方法相當於安卓開發中Activity的onCreate,遍歷字元串列表,使用pinyin-pro框架轉成拼音,再截取首字母轉成大寫,最後對數組進行排序,規則是:A-Z-#

initData(){
    const nameList = ["白虎","白天","白痴","常羲","嫦娥",
        "二郎神","伏羲","觀世音","精衛","誇父","789範德薩範德薩","女媧","哪吒",
        "盤古","青龍","如來","孫悟空","沙僧","順風耳","太白金星","太上老君","羲和","玄武",
        "豬八戒","朱雀","祝融","Abbey","Steven","Elizabeth","しんのすけ"];

    for(let i=0;i<nameList.length;i++){
        let pinyinStr=pinyin(nameList[i], { toneType: "none" });//根據姓名獲取拼音
        let index=pinyinStr.substring(0,1).toUpperCase();// 獲取拼音首字母並轉成大寫
        if (!/^[A-Z]$/.test(index)) { // 如果不在A-Z中則預設為“#”
            index = "#";
        }
        console.log(nameList[i]+" index:"+index)
        this.list.push(new Contact(index, nameList[i]));
    }

    this.list.sort((a, b) => {
        if (a.index === b.index) {
            return a.name.localeCompare(b.name);
        }
        if (a.index === "#") {
            return 1;
        }
        if (b.index === "#") {
            return -1;
        }
        return a.index.localeCompare(b.index);
    });
}

數據準備好了,接下來如何展示在界面上,ArkTS UI非常簡單,不像安卓要寫適配器、IOS要寫Cell,@Component組件必須要重寫build方法,在build方法中實現界面邏輯,首先最外層使用Row容器組件,一行顯示,

  • 左邊使用List組件載入列表,在迴圈列表中通過if判斷是否顯示字母
  • 右邊使用AlphabetIndexer組件展示26個字母,實現onSelect方法,用戶選中字母會回調這個方法
build() {
    Row() {
        List({ space: 0, initialIndex: 0,scroller:this.scroller}){//載入列表
            ForEach(this.list, (item:Contact,index) => {
                ListItem() {
                    Column(){
                        if (index==0||this.list[index-1].index != item.index){
                            Text(item.index).width('100%').fontColor('#333333').fontSize(14).backgroundColor("#EAEAEA").padding({
                                top:5,bottom:5,left:15
                            })
                        }

                        Text(item.name)
                            .fontSize(30)
                            .padding({
                                top:15,bottom:15,left:15
                            })
                    }.alignItems(HorizontalAlign.Start)
                }
            }, (item:Contact) => util.generateRandomUUID(true))//key隨機生成
        }.layoutWeight(1).scrollBar(BarState.Off)
        .height('100%').divider({
            color:'#E5E5E5',
            strokeWidth:0.5
        })

        AlphabetIndexer({ arrayValue: this.value, selected: 0})
            .selectedColor(0xFFFFFF) // 選中項文本顏色
            .popupColor(0xFFFAF0) // 彈出框文本顏色
            .selectedBackgroundColor(0xCCCCCC) // 選中項背景顏色
            .popupBackground(0xD2B48C) // 彈出框背景顏色
            .usingPopup(false) // 是否顯示彈出框
            .selectedFont({ size: 16, weight: FontWeight.Bolder }) // 選中項字體樣式
            .popupFont({ size: 30, weight: FontWeight.Bolder }) // 彈出框內容的字體樣式
            .itemSize(22) // 每一項的尺寸大小
            .alignStyle(IndexerAlign.Left) //彈出框在索引條右側彈出
            .onSelect((index: number) => {
                console.info(this.value[index] + ' Selected!')
                this.onSelectIndexItem(this.value[index]);
            })
    }
    .width('100%')
    .height('100%')
}

當用戶選中某個字母時,迴圈遍歷索引位置,通過scroller滾動到指定位置

onSelectIndexItem(index:string){
    for (let i=0;i<this.list.length;i++){
        console.log("名字:"+this.list[i].name+" index1:"+this.list[i].index+" index2:"+index)
        if (this.list[i].index == index){
            this.scroller.scrollToIndex(i)//滾動到索引位置
            break ;
        }
    }
}

AlphabetIndexer還可以通過usingPopup設置是否使用提示彈窗,大家可以自己去看API文檔。如果是安卓開發,實現這個功能代碼還是蠻多的,鴻蒙100行代碼就能實現這個功能了。

源碼下載

源碼:

https://github.com/ansen666/AlphabetIndexer

AlphabetIndexer組件API官方文檔:

https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V2/ts-container-alphabet-indexer-0000001427744828-V2

pinyin-pro框架:

https://ohpm.openharmony.cn/#/cn/detail/pinyin-pro

如果你想第一時間看我的後期文章,掃碼關註公眾號

      安輝編程筆記 - 開發技術分享
             掃描二維碼加關註


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL UDF 提權初探 對 MySQL UDF 提權做一次探究,什麼情況下可以提權,提取的主機許可權是否跟mysqld進程啟動的主機賬號有關 資料庫信息 MySQL資料庫版本:5.7.21 UDF UDF:(User Defined Function) 用戶自定義函數,MySQL資料庫的初衷是用 ...
  • 資料庫基礎知識 為什麼要使用資料庫? 數據保存在記憶體 優點:存取速度快 缺點:數據不能永久保存 數據保存在文件 優點:數據永久保存 缺點: 速度比記憶體操作慢,頻繁的IO操作。 查詢數據不方便 數據保存在資料庫 數據永久保存 使用SQL語句,查詢方便效率高。 管理數據方便 什麼是SQL? 結構化查詢語 ...
  • 事務複製中訂閱節點非活動( inactive)錯誤 在SQLServer的事務複製模型中,會出現“訂閱過期”的錯誤,相關訂閱分發代理Job的典型錯誤如下:"Agent SQLNYC01-Onvoices-PubInvoicesInvoices-SQLNYC01-1353 is retrying af ...
  • 《數據資產管理核心技術與應用》是清華大學出版社出版的一本圖書,全書共分10章,第1章主要讓讀者認識數據資產,瞭解數據資產相關的基礎概念,以及數據資產的發展情況。第2~8章主要介紹大數據時代數據資產管理所涉及的核心技術,內容包括元數據的採集與存儲、數據血緣、數據質量、數據監控與告警、數據服務、數據許可權 ...
  • 在當今數字化的時代,企業對於數據的管理和利用愈發重視,而構建全面的指標管理體系成為了企業提升數據價值、優化決策流程的關鍵環節。 構建完整的指標屬性體系 指標屬性體系是指標管理的核心,我們一般將指標屬性劃分為四類:基礎屬性、業務屬性、技術屬性和管理屬性。 基礎屬性:如指標名稱、編碼等。 業務屬性:如業 ...
  • 在實現用戶協議彈窗時,通常我們會想到使用系統自定義彈窗,併在彈窗中點擊跳轉到Web頁面。但在HarmonyOS中,由於系統彈窗的顯示優先順序高於其他組件,即使跳轉到Web頁面,彈窗依然會顯示在最上層。 為瞭解決這個問題,我們可以自定義一個組件來模擬彈窗,這樣當跳轉到Web頁面時,Web內容會覆蓋這個模 ...
  • 面向對象編程(OOP)是一種編程範式,它通過創建包含數據和方法的對象來組織代碼。相較於過程式編程,OOP 提供了更快更清晰的結構,有助於遵守 DRY(Don't Repeat Yourself)原則,使代碼更易於維護和擴展。在 Kotlin 中,類和對象是 OOP 的核心。類作為對象的模板,定義了對... ...
  • Kotlin中的迴圈結構讓你能輕鬆遍曆數組或範圍內的元素。使用`for`迴圈結合`in`操作符,可以簡潔地訪問數組中的每個項,如字元串數組或整數數組。對於範圍,可以用`..`來定義一系列連續的值併進行迭代。此外,Kotlin支持通過`break`和`continue`控制迴圈流程。函數則允許封裝可復... ...
一周排行
    -Advertisement-
    Play Games
  • 前言 推薦一款基於.NET 8、WPF、Prism.DryIoc、MVVM設計模式、Blazor以及MySQL資料庫構建的企業級工作流系統的WPF客戶端框架-AIStudio.Wpf.AClient 6.0。 項目介紹 框架採用了 Prism 框架來實現 MVVM 模式,不僅簡化了 MVVM 的典型 ...
  • 先看一下效果吧: 我們直接通過改造一下原版的TreeView來實現上面這個效果 我們先創建一個普通的TreeView 代碼很簡單: <TreeView> <TreeViewItem Header="人事部"/> <TreeViewItem Header="技術部"> <TreeViewItem He ...
  • 1. 生成式 AI 簡介 https://imp.i384100.net/LXYmq3 2. Python 語言 https://imp.i384100.net/5gmXXo 3. 統計和 R https://youtu.be/ANMuuq502rE?si=hw9GT6JVzMhRvBbF 4. 數 ...
  • 本文為大家介紹下.NET解壓/壓縮zip文件。雖然解壓縮不是啥核心技術,但壓縮性能以及進度處理還是需要關註下,針對使用較多的zip開源組件驗證,給大家提供個技術選型參考 之前在《.NET WebSocket高併發通信阻塞問題 - 唐宋元明清2188 - 博客園 (cnblogs.com)》講過,團隊 ...
  • 之前寫過兩篇關於Roslyn源生成器生成源代碼的用例,今天使用Roslyn的代碼修複器CodeFixProvider實現一個cs文件頭部註釋的功能, 代碼修複器會同時涉及到CodeFixProvider和DiagnosticAnalyzer, 實現FileHeaderAnalyzer 首先我們知道修 ...
  • 在軟體行業,經常會聽到一句話“文不如表,表不如圖”說明瞭圖形在軟體應用中的重要性。同樣在WPF開發中,為了程式美觀或者業務需要,經常會用到各種個樣的圖形。今天以一些簡單的小例子,簡述WPF開發中幾何圖形(Geometry)相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 在 C# 中使用 RabbitMQ 通過簡訊發送重置後的密碼到用戶的手機號上,你可以按照以下步驟進行 1.安裝 RabbitMQ 客戶端庫 首先,確保你已經安裝了 RabbitMQ 客戶端庫。你可以通過 NuGet 包管理器來安裝: dotnet add package RabbitMQ.Clien ...
  • 1.下載 Protocol Buffers 編譯器(protoc) 前往 Protocol Buffers GitHub Releases 頁面。在 "Assets" 下找到適合您系統的壓縮文件,通常為 protoc-{version}-win32.zip 或 protoc-{version}-wi ...
  • 簡介 在現代微服務架構中,服務發現(Service Discovery)是一項關鍵功能。它允許微服務動態地找到彼此,而無需依賴硬編碼的地址。以前如果你搜 .NET Service Discovery,大概率會搜到一大堆 Eureka,Consul 等的文章。現在微軟為我們帶來了一個官方的包:Micr ...
  • ZY樹洞 前言 ZY樹洞是一個基於.NET Core開發的簡單的評論系統,主要用於大家分享自己心中的感悟、經驗、心得、想法等。 好了,不賣關子了,這個項目其實是上班無聊的時候寫的,為什麼要寫這個項目呢?因為我單純的想吐槽一下工作中的不滿而已。 項目介紹 項目很簡單,主要功能就是提供一個簡單的評論系統 ...