摹熹 发表于 2025-7-28 19:56:48

uni-app项目跑APP报useStore报错

前情

uni-app是我比较喜欢的跨平台框架,它能开发小程序/H5/APP(安卓/iOS),重要的是对前端开发友好,自带的IDE让开发体验也挺棒的,现公司项目就是主推uni-app,最近手上项目就是要跑快手/抖音/微信/支付宝/APP多端的项目
坑位

最近负责的项目是使用Vue3+uview-plus+Pinia技术栈的项目,在跑小程序端的时候一切都算顺利,最近同事准备跑APP端的时候发现,控制台报如下错,我自己尝试跑了一下也报同样错

reportJSException >>>> exception function:createInstanceContext, exception:white screen cause create instanceContext failed,check js stack
at useStore (app-service.js:2211:15)
at (app-service. js:7552:20)
at (app-service. js:57237:3)why?

因为我以前有项目是有遇到这到过这种错误情况,就是使用Pinia的store的时候初始化的时机有问题
为什么小程序端没有问题,而APP端有问题,应该是小程序渲染进程和JS进程是二个独立进程,框架层做了额外的异步处理,掩盖了这个问题,而APP是使用原生 WebView(iOS/WKWebView 或 Android/Chrome),相当于是普通的浏览器渲染,此时就暴露出问题了
解决方案

在使用Pinia的store的时候,注意初始化时机,特别是在js文件中使用,可以把初始化状态放到函数中,不要在js文件顶层做初始化状态
//错误的示例

import { globalStore } from '@/store/global'

const globalInstance = globalStore()
export function test() {
// 使用globalInstance
}

// 正确的示例

import { globalStore } from '@/store/global'

export function test() {
    const globalInstance = globalStore()
// 使用globalInstance
}在组件中使用,一般像Vue3项目都是使用 setup语法糖的,一般不会有问题,如果你是使用选项式的写组件,那就要避免在组件顶层做状态文件初始化了,可以放到组件生命周期钩子里做初始化

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

屠焘 发表于 2025-10-17 00:41:59

感谢,下载保存了

圄旧剖 发表于 2025-12-20 00:30:59

前排留名,哈哈哈

荆邦 发表于 2025-12-26 19:39:56

谢谢楼主提供!

史华乐 发表于 2026-1-17 06:20:35

懂技术并乐意极积无私分享的人越来越少。珍惜

龙骋唧 发表于 2026-1-19 04:35:59

分享、互助 让互联网精神温暖你我

颓哀 发表于 2026-1-19 15:11:22

谢谢楼主提供!

损注 发表于 2026-1-20 08:54:50

用心讨论,共获提升!

怃膝镁 发表于 2026-1-20 12:54:37

不错,里面软件多更新就更好了

窟聿湎 发表于 2026-1-20 21:16:05

谢谢分享,试用一下

姚梨素 发表于 2026-1-26 08:38:22

感谢分享,下载保存了,貌似很强大

厌外 发表于 2026-1-26 11:28:42

谢谢楼主提供!

癖艺泣 发表于 2026-1-26 12:38:31

感谢分享

铜坠匍 发表于 2026-1-28 03:39:28

很好很强大我过来先占个楼 待编辑

悯拄等 发表于 2026-2-5 03:14:48

很好很强大我过来先占个楼 待编辑

何玲 发表于 2026-2-5 04:46:54

感谢分享,下载保存了,貌似很强大

师佳思 发表于 2026-2-5 05:24:17

新版吗?好像是停更了吧。

材部 发表于 2026-2-6 11:44:43

鼓励转贴优秀软件安全工具和文档!

廖彗云 发表于 2026-2-7 03:35:01

前排留名,哈哈哈

连热 发表于 2026-2-8 15:35:48

不错,里面软件多更新就更好了
页: [1] 2
查看完整版本: uni-app项目跑APP报useStore报错