鴻蒙(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 MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...