harmony-utils之JSONUtil,JSON工具类

简介: harmony-utils之JSONUtil是一款HarmonyOS平台下的高效JSON处理工具类,支持JSON字符串与对象、数组、Map之间的相互转换,简化数据解析与操作,提升开发效率。

harmony-utils之JSONUtil,JSON工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

API方法与使用


jsonToBean JSON字符串转对象
let objStr: string = '{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师","salary":9223372036854775807.2512,"user":{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师"}}';
let user = JSONUtil.jsonToBean(objStr, User);
beanToJsonStr 对象转JSON字符串
let user: User = new User();
let str = JSONUtil.beanToJsonStr(user);
jsonToArray JSON字符串转Array
let arrayStr = ResUtil.getRawFileContentStrSync('data_utils.json');
let array = JSONUtil.jsonToArray<DescribeBean>(this.arrayStr);
array.forEach((item, index) => {
  LogUtil.error(`${index} - ${JSON.stringify(item)}`);
});
jsonToMap JSON字符串转Map
let mapStr: string = '{"id":"NO_10000011","name":"王五五","age":"30","addr":"乌市天山区","work":"攻城狮","salary":9223372036854775807.2512}';
let map = JSONUtil.jsonToMap(mapStr);
map.forEach((value, key) => {
  LogUtil.error(`${key} - ${value}`);
});
mapToJsonStr Map转JSON字符串
let mapStr: string = '{"id":"NO_10000011","name":"王五五","age":"30","addr":"乌市天山区","work":"攻城狮","salary":9223372036854775807.2512}';
let map = JSONUtil.jsonToMap(mapStr);
isJSONStr 判断是否是字符串格式json
let objStr: string = '{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师","salary":9223372036854775807.2512,"user":{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师"}}';
let b1 = JSONUtil.isJSONStr(objStr);
let b2 = JSONUtil.isJSONStr("abcd1234");

示例代码


import {
    router } from '@kit.ArkUI';
import {
    MockSetup } from '@ohos/hamock';
import {
    JSONUtil, LogUtil, ResUtil, ToastUtil } from '@pura/harmony-utils';
import {
    TitleBarView } from '../../component/TitleBarView';
import {
    DescribeBean } from '../../model/DescribeBean';
import {
    User } from '../../model/User';


/**
 * JSON工具类
 */
@Entry
@Component
struct Index {
   
  private scroller: Scroller = new Scroller();
  @State describe: DescribeBean = router.getParams() as DescribeBean;
  private readonly objStr: string = '{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师","salary":9223372036854775807.2512,"user":{"id":"No_1060701","name":"张三","age":20,"addr":"乌市天山区","work":"工程师"}}';
  private readonly mapStr: string = '{"id":"NO_10000011","name":"王五五","age":"30","addr":"乌市天山区","work":"攻城狮","salary":9223372036854775807.2512}';
  @State arrayStr: string = '';

  @MockSetup
  mock() {
   
    this.describe = new DescribeBean("JSONUtil", "JSON工具类");
  }

  aboutToAppear(): void {
   
    ResUtil.getRawFileContentStr('data_utils.json').then((result) => {
   
      this.arrayStr = result;
    })
  }

  onBackPress(): boolean {
   
    return false;
  }

  build() {
   
    Column() {
   
      TitleBarView({
    describe: this.describe })
      Divider()
      Scroll(this.scroller) {
   
        Column() {
   
          Button("jsonToBean()")
            .btnStyle()
            .onClick(() => {
   
              let user = JSONUtil.jsonToBean(this.objStr, User);
              LogUtil.error(`${
     user instanceof User}`);
              LogUtil.error(`${
     user?.name} - ${
     user?.age} - ${
     user?.addr} - ${
     user?.work} - ${
     user?.salary} - ${
     user?.id}`)
              user?.say("麻辣豆腐!");
              ToastUtil.showToast("请查看Log日志");
            })
          Button("beanToJsonStr()")
            .btnStyle()
            .onClick(() => {
   
              let user: User = new User();
              let str = JSONUtil.beanToJsonStr(user);
              LogUtil.error(`JSON字符串: ${
     str}`)
              ToastUtil.showToast("请查看Log日志")
            })
          Button("jsonToArray()")
            .btnStyle()
            .onClick(() => {
   
              ResUtil.getRawFileContentStrSync('data_utils.json')
              let array = JSONUtil.jsonToArray<DescribeBean>(this.arrayStr);
              array.forEach((item, index) => {
   
                LogUtil.error(`${
     index} - ${
     JSON.stringify(item)}`)
              })
              ToastUtil.showToast("请查看Log日志");
            })
          Button("jsonToMap()")
            .btnStyle()
            .onClick(() => {
   
              let map = JSONUtil.jsonToMap(this.mapStr);
              map.forEach((value, key) => {
   
                LogUtil.error(`${
     key} - ${
     value}`);
              })
              ToastUtil.showToast("请查看Log日志");
            })
          Button("mapToJsonStr()")
            .btnStyle()
            .onClick(() => {
   
              let map = JSONUtil.jsonToMap(this.mapStr);
              let JsonStr = JSONUtil.mapToJsonStr(map);
              LogUtil.error("JsonStr: " + JsonStr);
              ToastUtil.showToast("请查看Log日志");
            })

          Button("isJSONStr()")
            .btnStyle()
            .onClick(() => {
   
              let b1 = JSONUtil.isJSONStr(this.objStr);
              let b2 = JSONUtil.isJSONStr(this.arrayStr);
              let b3 = JSONUtil.isJSONStr(this.mapStr);
              let b4 = JSONUtil.isJSONStr("abcd1234");
              LogUtil.error(`b1: ${
     b1}\nb2: ${
     b2}\nb3: ${
     b3}\nb4: ${
     b4}`)
              ToastUtil.showToast("请查看Log日志")
            })

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


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

创作不易,请给童长老点赞👍


https://github.com/787107497/harmony-utils
https://gitee.com/tongyuyan/harmony-utils
OpenHarmony三方库

目录
相关文章
|
8月前
|
API Apache Android开发
最受欢迎的三方库之harmony-web
`harmony-web` 是基于鸿蒙 WebView 构建的轻量级库,提供丰富的功能与问题解决方案,简化 WebView 开发。结合 `harmony-utils` 与 `harmony-dialog`,可快速构建高效、易用的鸿蒙应用。支持 ArkWeb 组件与多种配置选项,助力开发者高效实现网页加载、交互及弹窗功能。开源协议为 Apache License 2.0。
253 0
|
8月前
|
JSON 生物认证 API
harmony-utils之StrUtil,字符串工具类
harmony-utils 是一款专为HarmonyOS开发的高效工具库,提供丰富的字符串处理功能。其字符串工具类StrUtil支持判空、去空格、替换、大小写转换、编码转换等常用操作,简化字符串处理逻辑,提升开发效率。适用于鸿蒙应用开发中的各类字符串场景。
291 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PreviewUtil,文件预览工具类
PreviewUtil 是 harmony-utils 工具库中的文件预览工具类,提供生成预览信息、打开/关闭预览窗口、加载预览数据、判断预览支持等功能,助力鸿蒙应用快速实现文件预览操作。
275 0
|
8月前
|
API Apache 开发者
最受欢迎的三方库之mime-types
`mime-types` 是一款用于处理文件 MIME 类型的 OpenHarmony 工具库,支持根据文件名、扩展名或 MIME 类型获取对应信息,并提供文件图标与类型描述符查询功能,适用于 HarmonyOS 应用开发。
255 0
|
8月前
|
iOS开发
harmony-dialog预览效果
harmony-dialog 是一款简单易用、零侵入的弹窗组件,支持多种类型如确认框、提示框、输入框、选择器、加载框等,覆盖常见开发需求。
257 0
harmony-dialog预览效果
|
API Apache 开发者
最受欢迎的三方库之EventBus
EventBus 是一款支持 Sticky 和跨 App 广播的消息总线,适用于 HarmonyOS 开发。提供丰富的 API,如事件监听、消息发布等,助力高效构建应用。
243 0
|
JSON API Apache
最受欢迎的三方库之china_area
`@nutpi/china_area` 是一款提供中国省、市、县三级区域数据的 OpenHarmony 工具库,支持同步与异步调用方式,便于快速集成至鸿蒙应用中。配套 `@pura/harmony-utils` 与 `@pura/harmony-dialog` 可实现高效开发,如地区选择器等交互功能。API 简洁易用,附有完整示例代码,助力开发者提升效率。项目遵循 Apache License 2.0 协议,欢迎参与共建。
233 0
|
JSON 生物认证 API
harmony-utils之KeyboardUtil,键盘工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,提供丰富的工具类以提升开发效率。其子库 picker_utils 包含 PickerUtil、PhotoHelper 和 ScanUtil,适用于各类应用开发场景。
177 0
|
JSON 搜索推荐 生物认证
harmony-utils之ToastUtil,吐司工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,包含丰富的工具类,如吐司(ToastUtil)、设备、通知、线程通信等,帮助开发者高效开发鸿蒙应用。支持快速集成与个性化配置,提升开发效率。
210 0
|
JSON 生物认证 API
harmony-utils之TempUtil,温度转换工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供 TempUtil 温度转换工具类,支持摄氏度、华氏度与开尔文之间的相互转换,助力开发者高效构建鸿蒙应用。
248 0