由于报错信息不详,即使给hvigor.js 提供--stacktrace 级别的日志也无法定位具体模块。
解决方案:修改编译源码js。
1、定位具体js:我的定位是:/Users/xdg/.hvigor/project_caches/489b334bc29a5a8428674c766cdae532/workspace/node_modules/.pnpm/@ohos+hvigor-ohos-plugin@2.4.2_@ohos+hvigor@2.4.2/node_modules/@ohos/hvigor-ohos-plugin/src/tasks/merge-profile.js。
定位js的方法可以通过给hvigor.js提供 --stacktrace 参数解决。
2、由于编译js都是经过压缩的,经过实验使用webstorm然后安装eslint插件能够重新美化js,使js变得可读。
3、定位js具体源码,此处我是定位到了具体方法,然后打印日志,如下:
4、重要:需要关闭 dameon模式,具体在编译参数后加--stop-daemon即可。否则你修改的js不会生效。
5、验证。经过重新编译,输出日志信息。这个步骤的o变量拥有模块的信息,如下:
果然是pulltorefresh模块的编译api版本大于工程配置的api导致的。我采用的方法是固定pulltorefresh版本,后续开发尽量不要用^的形式,否则会导致不兼容问题。