HarmonyOS 鸿蒙Next页面传参后对象出错

发布于 1周前 作者 nodeper 来自 鸿蒙OS

HarmonyOS 鸿蒙Next页面传参后对象出错 我这边对象生成了默认的get、set方法,然后该对象通过router的传参方式传到下一个页面,转换后的对象通过get方法无法获取到对应的属性值,代码片段如下

private _appID = "";
public set AppID(value) { 
this._appID = value; 
} 
public get AppID() { 
return this._appID; 
} 
 
router.pushUrl(
{ url: 'pages/WebPage', params : item 
})
this.moduleItem = router.getParams() as MoudleItemDbBean
 
this.moduleItem.AppID

这里获取出来为null


更多关于HarmonyOS 鸿蒙Next页面传参后对象出错的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

paramas不支持传递方法和系统返回的对象,可参考以下传值方式:

router.pushUrl({
    url: 'pages/routerpage2',
    params: new routerParams('message' ,[123,456,789])
})

或者

router.push({
    uri: 'pages/routerpage2/routerpage2',
    params: {
        data1: 'message',
        data2: {
            data3: [123, 456, 789]
        }
    }
});

具体可查看文档: https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-router-V5#routeroptions

更多关于HarmonyOS 鸿蒙Next页面传参后对象出错的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


针对HarmonyOS(鸿蒙)系统中Next页面传参后对象出错的问题,可能的原因及解决方法如下:

对象序列化问题:

鸿蒙系统在页面间传递复杂对象时,需要确保对象是可序列化的。检查你的对象是否实现了必要的序列化接口或使用了鸿蒙提供的序列化机制。如果对象包含不可序列化的属性,可能会导致传参失败或出错。

参数类型不匹配:

确保接收页面期望的参数类型与发送页面传递的参数类型完全一致。类型不匹配会导致数据解析错误。

生命周期问题:

如果传参发生在页面生命周期的某个特定阶段(如onPause或onDestroy后),可能会导致接收页面未能正确接收参数。确保传参操作在页面活跃且准备好接收数据时进行。

数据丢失或损坏:

检查传参过程中是否有数据丢失或损坏的情况。使用鸿蒙提供的日志工具检查传参前后的数据状态,确保数据完整性和正确性。

如果以上方法均未能解决问题,可能是鸿蒙系统内部或特定版本的bug。此时,建议直接联系鸿蒙系统的官方客服以获取更专业的帮助。

如果问题依旧没法解决请联系官网客服,官网地址是 https://www.itying.com/category-93-b0.html

回到顶部