Router传递Object对象解读

Router传递Object对象解读

HarmonyOS
2024-05-26 18:01:17
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
trobust

Router传递Object对象解读

Router传递Object对象时,实际在底层使用了JSON.stringify()序列化为JSON字符串进行的。由于JSON 不允许包含函数,JSON.stringify()会删除 JavaScript 对象的函数,所以只能用来传递对象的属性值,不能传递function。如下示例可以验证:

export default class Student { 
  constructor(name:string) { 
    this.name = name 
  } 
  name:string 
  getName() { 
    return this.name; 
  } 
} 
 
@Entry 
@Component 
struct Index { 
  build() { 
    Column() { 
      Button() 
        .onClick(() => { 
          let stu = new Student('OpenHarmony') 
          router.pushUrl({ url: 'pages/other', params: stu }) 
        }) 
    } 
  } 
} 
 
@Entry 
@Component 
struct Other { 
  @State message: string = 'Other' 
 
  onPageShow() { 
    let stu = router.getParams() as Student 
    console.info(`student prop name = ${stu.name}`) 
    try { 
      console.info(`student func getName = ${stu.getName()}`) 
    } catch (e) { 
      console.info(`student getName err = ${JSON.stringify(e)}`) 
    } 
  } 
 
  build() { 
    Row() { 
      Column() { 
        Text(this.message) 
          .fontSize(50) 
          .fontWeight(FontWeight.Bold) 
      } 
      .width('100%') 
    } 
    .height('100%') 
  } 
}

onLoadIntercept志打印:能获取对象的属性值,但是使用成员函数时会报错。

分享
微博
QQ
微信
回复
2024-05-27 22:51:07
相关问题
router传递hashmap参数问题
1489浏览 • 1回复 待解决
HarmonyOS router.getParams()数据传递
339浏览 • 1回复 待解决
router路由中的params对象
222浏览 • 1回复 待解决
返回页面router.back如何传递参数
780浏览 • 2回复 待解决
如何获取router.back传递的参数
2519浏览 • 1回复 待解决
如何将Map/HashMap转为Object对象
1742浏览 • 1回复 待解决
HarmonyOS Web组件注入js怎么传递对象
354浏览 • 1回复 待解决
ArkTs怎么传递对象或者类给Native
2198浏览 • 1回复 待解决
如何实现ArkTS与C/C++的对象传递
480浏览 • 1回复 待解决