最受欢迎的三方库之china_area

简介: `@nutpi/china_area` 是一款提供中国省、市、县三级区域数据的 OpenHarmony 工具库,支持同步与异步调用方式,便于快速集成至鸿蒙应用中。配套 `@pura/harmony-utils` 与 `@pura/harmony-dialog` 可实现高效开发,如地区选择器等交互功能。API 简洁易用,附有完整示例代码,助力开发者提升效率。项目遵循 Apache License 2.0 协议,欢迎参与共建。

china_area

🏆简介与推荐

china_area 中国区域数据,省市县三级数据。

harmony-utils
一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。

harmony-dialog
一款极为简单易用的零侵入弹窗,仅需一行代码即可轻松实现,无论在何处都能够轻松弹出。

🌞下载安装

ohpm i @nutpi/china_area
OpenHarmony ohpm
环境配置等更多内容,请参考如何安装 OpenHarmony ohpm 包

📚API详解 使用案例

AreaHelper方法 介绍
getAreaStrSync
getAreaStr
获取省市县的JSON字符串
getAreaSync
getArea
获取省市县的数据
getCityByNameSync
getCityByName
根据省名获取下面的市
getDistrictByNameSync
getDistrictByName
根据市名获取下面的区县

📚示例代码

//获取省市县的JSON字符串
let txtStr = await AreaHelper.getAreaStr();
let areaList = JSONUtil.jsonToArray<AreaEntity>(txtStr);


//获取省市县的数据
let areas = AreaHelper.getAreaSync();


//根据省名获取下面的市
let citys = await AreaHelper.getCityByName("安徽省");


//根据市名获取下面的区县
let list = AreaHelper.getDistrictByNameSync("合肥市");


//配合‘@pura/harmony-dialog’的\nshowTextPickerDialog()方法使用
let data = AreaHelper.getAreaSync();
DialogHelper.showTextPickerDialog({
  title: "请选择",
  range: data,
  onChange: (value: string | string[], index: number | number[]) => {
    LogUtil.error(`value: ${value} --- index: ${index}`);
  },
  onAction: (action: number, dialogId: string, value: string | string[]) => {
    if (action === DialogAction.SURE) {
      DialogHelper.showToast(`已选择:${value}`);
    }
  }
});
import {
    router } from '@kit.ArkUI';
import {
    AreaEntity, AreaHelper } from '@nutpi/china_area';
import {
    JSONUtil, LogUtil, StrUtil } from '@pura/harmony-utils';
import {
    TitleBarView } from '../../component/TitleBarView';
import {
    DescribeBean } from '../../model/DescribeBean';
import {
    JSON } from '@kit.ArkTS';
import {
    DialogAction, DialogHelper } from '@pura/harmony-dialog';

/**
 * @nutpi/china_area,使用案例
 */
@Entry
@ComponentV2
export struct ChinaAreaPage {
   
  private scroller: Scroller = new Scroller();
  @Local describe: DescribeBean = router.getParams() as DescribeBean;
  @Local txtStr: string = "";


  build() {
   
    Column() {
   
      TitleBarView({
    describe: this.describe })
      Divider()
      Scroll(this.scroller) {
   
        Column({
    space: 5 }) {
   
          Button("getAreaStr()")
            .btnStyle()
            .onClick(async () => {
   
              this.txtStr = await AreaHelper.getAreaStr();
              let data = JSONUtil.jsonToArray<AreaEntity>(this.txtStr);
              DialogHelper.showToast(`${
     data.length}`);
            })
          Button("getAreaStr()")
            .btnStyle()
            .onClick(async () => {
   
              let list = await AreaHelper.getArea();
              LogUtil.error(`长度:${
     list.length}`);
              this.txtStr = JSON.stringify(list,null,2);
            })
          Button("getCityByName()")
            .btnStyle()
            .onClick(async () => {
   
              let citys = await AreaHelper.getCityByName("安徽省");
              this.txtStr = JSON.stringify(citys, null, 2);
            })
          Button("getDistrictByNameSync()")
            .btnStyle()
            .onClick(() => {
   
              let list = AreaHelper.getDistrictByNameSync("合肥市");
              this.txtStr = JSON.stringify(list, null, 2);
            })
          Button("配合‘@pura/harmony-dialog’的\nshowTextPickerDialog()方法使用")
            .labelStyle({
    maxLines: 3 })
            .padding({
    top: 10, bottom: 10 })
            .btnStyle()
            .onClick(() => {
   
              this.txtStr = "";
              let data = AreaHelper.getAreaSync();
              DialogHelper.showTextPickerDialog({
   
                title: "请选择",
                range: data,
                onChange: (value: string | string[], index: number | number[]) => {
   
                  LogUtil.error(`value: ${
     value} --- index: ${
     index}`);
                },
                onAction: (action: number, dialogId: string, value: string | string[]) => {
   
                  if (action === DialogAction.SURE) {
   
                    DialogHelper.showToast(`已选择:${
     value}`);
                  }
                }
              });
            })

          Blank().layoutWeight(1)

          Text(this.txtStr)
            .visibility(StrUtil.isNotEmpty(this.txtStr) ? Visibility.Visible : Visibility.None)
            .textStyle()

          Blank().layoutWeight(1)
        }
        .margin({
    top: 5, bottom: 5 })
      }
      .layoutWeight(1)
    }
    .width('100%')
    .height('100%')
    .backgroundColor($r('app.color.main_background'))
  }
}


@Styles
function btnStyle() {
   
  .width('90%')
  .margin({
    top: 10, bottom: 5 })
}

@Styles
function textStyle() {
   
  .width('95%')
  .padding(10)
  .shadow(ShadowStyle.OUTER_DEFAULT_XS)
  .margin({
    top: 5, bottom: 10 })
  .border({
   
    width: 1,
    color: Color.Grey,
    radius: 10,
    style: BorderStyle.Dashed
  })
}

🍎沟通与交流🙏

使用过程中发现任何问题都可以提 Issue给我们;
当然,我们也非常欢迎你给我们发 PR

🌏开源协议

本项目基于 Apache License 2.0 ,在拷贝和借鉴代码时,请大家务必注明出处。

目录
相关文章
|
API Apache 开发者
最受欢迎的三方库之EventBus
EventBus 是一款支持 Sticky 和跨 App 广播的消息总线,适用于 HarmonyOS 开发。提供丰富的 API,如事件监听、消息发布等,助力高效构建应用。
212 0
|
5月前
|
API Apache Android开发
最受欢迎的三方库之harmony-web
`harmony-web` 是基于鸿蒙 WebView 构建的轻量级库,提供丰富的功能与问题解决方案,简化 WebView 开发。结合 `harmony-utils` 与 `harmony-dialog`,可快速构建高效、易用的鸿蒙应用。支持 ArkWeb 组件与多种配置选项,助力开发者高效实现网页加载、交互及弹窗功能。开源协议为 Apache License 2.0。
182 0
|
JSON 生物认证 API
harmony-utils之JSONUtil,JSON工具类
harmony-utils之JSONUtil是一款HarmonyOS平台下的高效JSON处理工具类,支持JSON字符串与对象、数组、Map之间的相互转换,简化数据解析与操作,提升开发效率。
203 0
|
缓存 JSON 算法
harmony-utils之LRUCacheUtil,LRUCache缓存工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供多种实用工具类,助力开发者快速构建鸿蒙应用。其中 LRUCacheUtil 是基于 LRU 算法的缓存工具类,支持获取、添加、删除、清空缓存等操作,并可自定义缓存容量,适用于高效管理内存缓存场景。
150 0
|
JSON 生物认证 API
harmony-utils之KeyboardUtil,键盘工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,提供丰富的工具类以提升开发效率。其子库 picker_utils 包含 PickerUtil、PhotoHelper 和 ScanUtil,适用于各类应用开发场景。
154 0
|
JSON 搜索推荐 生物认证
harmony-utils之ToastUtil,吐司工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,包含丰富的工具类,如吐司(ToastUtil)、设备、通知、线程通信等,帮助开发者高效开发鸿蒙应用。支持快速集成与个性化配置,提升开发效率。
184 0
|
JSON 前端开发 生物认证
harmony-utils之SnapshotUtil,截图相关工具类
harmony-utils是一款专为HarmonyOS开发的高效工具库,提供丰富的实用功能,助力开发者快速构建鸿蒙应用。其中的SnapshotUtil类专注于截图功能,支持组件截图、自定义Builder渲染截图、窗口截图及系统截屏监听等操作,极大提升了开发效率与应用交互体验。
192 0
|
JSON 生物认证 API
harmony-utils之TempUtil,温度转换工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供 TempUtil 温度转换工具类,支持摄氏度、华氏度与开尔文之间的相互转换,助力开发者高效构建鸿蒙应用。
201 0
|
JSON 生物认证 API
harmony-utils之RegexUtil,正则工具类
RegexUtil 是 harmony-utils 中的正则工具类,提供多种常用正则验证方法,如验证手机号、邮箱、身份证、数字、URL 等。支持快速判断字符串是否匹配特定格式,助力 HarmonyOS 开发高效便捷。
181 0
|
存储 JSON 生物认证
harmony-utils之AssetUtil,关键资产存储服务工具类
AssetUtil 是 harmony-utils 工具库中的关键资产存储服务工具类,提供新增、查询、删除资产等功能,支持同步与异步操作,适用于 HarmonyOS 应用开发。
193 0