收藏
评论

(15)真机定位问题技巧官方

开发者在开发小程序的时候可能会碰到一些这样的问题:


问题1  开发者工具上看效果没问题,但是在真机上测试不行?


问题2  有用户遇到小程序功能无法使用的问题,但无法快速定位解决?


今天我们的小故事与大家分享一些真机定位的技巧,可以解决上面两个问题。


1

vConsole开发利器和远程调试功能


针对问题1,我们提供了 vConsole 开发利器和远程调试功能,可以协助开发者在定位真机上的问题。


vConsole 的有四个Tab面板,可以先看下 Log 面板,看是否有异常信息,异常类型 thirdScriptError 是框架捕捉到的开发者的代码执行的异常,可以优先处理异常信息看是否可以解决问题。Log 面板可以看到异常出现的文件和行数。




除了异常日志,开发者还可以通过 console.log 接口在一些关键执行路径上打日志来定位问题,这些日志会呈现在 Log 面板上。


vConsole 默认是不开启的,可以通过下面2个方法来开启:


1 开发版和体验版可以点击小程序页面右上角的...按钮打开的菜单项“打开调试”来开启 vConsole。


2 正式版没有“打开调试”的菜单项,可以先通过开发版和体验版来开启 vConsole,然后再打开正式版。或者可以预埋一个隐藏操作,比如连续点击某个 Button 多次,然后调用 API 接口 wx.setEnableDebug 来打开。


vConsole 虽然强大,但在手机上查看大量的日志信息不方便,此外,vConsole 没有断点调试、无法修改样式,定位复杂问题需要花费比较多的时间。


小程序的业务逻辑运行在 AppService 层,页面渲染在 WebView 运行,并通过微信客户端通信,因此,我们想到了可以让 AppService 运行在开发者工具,页面渲染还是在手机 WebView,两者通过网络来通信,这样借助开发者工具的调试能力,就可以实现远程调试功能


远程调试窗口通过手机客户端扫描开发者工具上生成的二维码来打开,无需像普通手机 H5 页面调试一样,需要在手机端进行一些设置。




打开的远程调试界面和开发者工具的模拟器的调试界面很像,需要注意的是,要在 Console 里对小程序进行调试,需要将调试的上下文切换到 VM Context 1 。




更多的远程调试的使用方法请参考使用文档


2

意见反馈能力


对于问题2,小程序的使用反馈来自用户投诉,这种情况用户无法联系到开发者。我们遇见过有小程序功能出现问题,用户无法使用,但投诉无门的情况,而这些问题,开发者也没有途径去收集以及处理,这就导致了小程序服务质量下降,用户流失。


为此,我们开发了“意见反馈”功能,当出现问题时,开发者可以引导用户使用“意见反馈”进行反馈,并上传日志来辅助开发者定位问题。操作过程如下:


引导用户进入小程序帐号详情页面,具体可以在小程序界面点击右上角...按钮,选择关于菜单。接着在帐号详情页面点击右上角...按钮,选择意见反馈菜单进入页面。页面可以上传图片和日志,建议用户上传异常情况的截图,以及勾选允许开发者使用小程序日志选项上传日志,反馈信息越详细,越有助于定位问题。




如果觉得上面的操作步骤太麻烦,开发者可以通过在页面 WXML 添加下面的按钮,用户点击按钮可以直接打开“意见反馈”页面。



开发者需要定时处理用户的反馈,这样才能保证小程序的质量。开发者可以登录小程序管理后台,进入左侧菜单客服反馈,就可以看到用户的反馈内容以及下载日志来辅助定位问题。


为了保证日志信息足够详细,开发者需要用下面的接口在代码的关键执行路径上写日志。



wx.getLogManager 接口的更详细使用请参考文档


希望通过这些小技巧,可以帮助大家顺畅地开发小程序。

66346浏览
最后一次编辑于  2019-04-29
知识库内容非实时更新,可能已过期、失效或不适用于当前情形,请谨慎参考
收藏
反馈

21 个评论

  • 风中追风
    风中追风
    2018-07-12

    开发工具报错机制太不完善了

    2018-07-12
    赞同 1
    回复
  • 辄夜花泽
    辄夜花泽
    2018-08-22

    小程序连接数据库??


    2018-08-22
    赞同
    回复
  • egg🍳
    egg🍳
    2018-07-25

    fundebug了解一下

    2018-07-25
    赞同
    回复
  • 2018-07-19

    远程调试效果跟预览效果不一样怎么说?

    2018-07-19
    赞同
    回复
  • 楼航飞
    楼航飞
    2018-07-19

    在小游戏我用小程序自带的api来记录日志。


    logger = wx.getLogManager()
    logger.log()

    而且在客户端的反馈客服那里也勾选了允许开发者使用当前日志。

    但是在小游戏的后台客服反馈功能那里,为什么没有日志下载功能呢?

    2018-07-19
    赞同
    回复
  • Journey。
    Journey。
    2018-06-27

    类似wx.setEnableDebug这样的  请问能不能在文档上开放更多这样有却在文档里没有的接口

    2018-06-27
    赞同
    回复
  • 呃
    2018-06-26

    Mark

    2018-06-26
    赞同
    回复
  • 白山的天很蓝
    白山的天很蓝
    2018-06-25

    一给握力GIAOGIAO!

    2018-06-25
    赞同
    回复
  • ꯭ Z ꯭、꯭ z ꯭ ꯭
    ꯭ Z ꯭、꯭ z ꯭ ꯭
    2018-06-25

    沙发

    2018-06-25
    赞同
    回复
  • 大师兄
    大师兄
    2018-06-25

    沙发

    2018-06-25
    赞同
    回复

正在加载...

登录 后发表内容