HarmonyOS 使用JSON.parse转json对象取值为undefined

使用JSON.parse转json对象,这个json对象明明有值,直接通过obj['xx'],为什么undefined了?

HarmonyOS
2024-12-27 14:48:07
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
zxjiu

1、可以使用HarmonyOS封装的ESObject对象。

 let obj:ESObject = JSON.parse('{"u":123,"v":"abc","w":true}')
 obj['u'] = 1234
 obj['v']='def'
 console.log( obj['u'], obj['v'])
  • 1.
  • 2.
  • 3.
  • 4.

2、使用三方库 reflect-metadata 和 class-transformer。

class-transformer 地址:https://gitee.com/openharmony-tpc/openharmony_tpc_samples/tree/master/class-transformer,本库提供对象和类之间基于修饰符的转换、序列化和反序列化的能力。

reflect-metadata地址:https://gitee.com/openharmony-tpc/openharmony_tpc_samples/tree/master/reflect-metadata,用于在TypeScript中操作类的元数据,允许在声明类和属性时添加和读取元数据。

// Index.ets
let jsonString:Record<string, ESObject> = {
  "data" : [
    {
      "number" :1,
      "age": 20,
      "testA": {
        "str" : "123"
      }
    },
    {
      "number" :2,
      "age": 21,
      "testA": {
        "str" : "456"
      }
    }
  ]
}
import { Type, plainToClass } from 'class-transformer'
import 'reflect-metadata'
import { TestA, Person, ViewA} from './ViewA';
class ResponseObj {
  @Type (() => Person)
  data: Person[] = [];
}
@Entry
@Component
struct Index {
  @State list: Person[] = [];
  @State message: string = 'Click me';
  build() {
    Row() {
      Column() {
        Text(this.message).fontSize(40).onClick(() => {
          let responseObj : ResponseObj = plainToClass(ResponseObj, jsonString);
          console.log( ${responseObj.data[0] instanceof Person})
          this.list = this.list.concat(responseObj.data);
        })
        ForEach(this.list, (item : Person, index: number) => {
          ViewA({index:index, testA: item.testA})
        })
      }
      .width('100%')
    }
    .height('100%')
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
// ViewA.ets
import { Type } from 'class-transformer'
@Observed
export class TestA {
  public str : string
  constructor(str: string) {
    this.str = str;
  }
}
export class Person {
  name: string = ''
  age: number = 1
  @Type(()=>TestA)
  testA: TestA = new TestA('')
}
@Component
export struct ViewA {
  @ObjectLink testA: TestA
  index: number = -1;
  build() {
    Row(){
      Button(View A ${this.testA.str}).onClick(() =>{
        this.index += 1;
        this.testA.str = ${this.index} : Test A String
      })
    }.margin({top : 10 })
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
分享
微博
QQ
微信
回复
2024-12-27 16:45:42
相关问题
HarmonyOS JSON.parse 返回类型问题
1611浏览 • 1回复 待解决
JSON.parse数据处理导致精度丢失问题
1487浏览 • 1回复 待解决
HarmonyOS mapjson对象
911浏览 • 1回复 待解决
HarmonyOS JSON对象失败
1025浏览 • 1回复 待解决
HarmonyOS json对象map类型
1035浏览 • 1回复 待解决
json解析对象后获取数据返回undefined
1730浏览 • 1回复 待解决
HarmonyOS JSON数据怎么获取值
735浏览 • 1回复 待解决
HarmonyOS 多层动态嵌套JSON如何取值
853浏览 • 1回复 待解决
HarmonyOS Jsonmap该使用哪个接口
857浏览 • 1回复 待解决
如何将JSON字符串Class对象
1132浏览 • 1回复 待解决
HarmonyOS JSON怎么Map?
1161浏览 • 1回复 待解决
如何将JSON字符串Class对象数组?
1255浏览 • 1回复 待解决
HarmonyOS hashmap如何json格式?
915浏览 • 1回复 待解决