• ionic 调试 "死亡白屏"


    死亡白屏(White Screen of Death)

    我想“死亡白屏”应该是不需要解释的,开发过ionic app的童鞋应该都有遇到过,这里解释以防读者没有听说过:“可能在浏览器中调试时一切正常,当你在真机或模拟器上测试时不正常,当app启动时只有空白的页面”。

    在我的开发中,死亡白屏经常是因为缺失了JavaScript文件,这就中断了Angular初始化app的过程,从而不能加载我们的视图模板,所以显示空白的页面。

    不幸的是,导致“死亡白屏”的原因多种多样,不能确切的说明是什么原因,因为在真机或模拟器上没有控制台。

    下面,就介绍2种调试的方法:

    ionic Live Reload

    谈到ionic Live Reload,我想开发过ionic的童鞋都应该知道,当使用ionic serve在浏览器中调试时,改变代码会使页面重新加载,从而极大的方便了我们的调试。

    当使用真机或模拟器时,即使用ionic runionic emulate命令时加上–consolelogs参数,即可在终端中输出app的相关信息:

    $ ionic run/emulate android/ios --consolelogs
    
    $ ionic run android --consolelogs

    但是–consolelogs参数不能单独使用,需配合–livereload参数使用,即:

    $ ionic run/emulate android/ios --livereload --consolelogs
    
    $ ionic run android --livereload --consolelogs

    或者使用简写版本:

    $ ionic run/emulate android/ios -l -c
    
    $ ionic run android -l -c

    其中 -l 代表 –livereload-c 代表 –consolelogs

    Live Reload option的作用和浏览器调试下的ionic serve作用类似,当调试过程中改变了代码,真机/模拟器上的app会自动更新。但是需要注意的是,对于插件的任何改变都会导致app的重新构建(rebuild)。Live Reload option起作用还有个前提:你的主机和测试设备或模拟器需要处于同一局域网,并且测试设备或模拟器必须支持web sockets

    如果测试时,某个依赖模块不存在或者不能被Angular找到,可能的输出如下: 

    这里写图片描述

    Chrome Developer Tools

    谈及Chrome Developer Tools可以说是无人不知了,Chrome不仅有简洁的界面,还有强大的Chrome Developer Tools,调试利器。但是对于ionic app来说,Chrome Developer Tools只能对android真机或android模拟器进行调试。

    1. 首先,使用USB线连接你的主机和android测试机,确保你的测试机已经打开了USB调试并已经允许你的主机对你的android测试机进行调试;
    2. 然后,打开Chrome浏览器,地址栏输入chrome://inspect,回车;
    3. 现在网页中应该能看到你的设备,如果没有看到,可以参照官方文档(自备梯子)。这里我使用的是模拟器: 
      这里写图片描述

    点击inspect,Chrome会新建一个调试窗口,剩下的就和网页的调试一样了,看一眼Console,可能会看到如下结果: 
    这里写图片描述

    结语

    可以看到,最简单实用的方式是使用Live Reload参数,适用于Android和IOS,如果只是调试Android,那么使用Chrome Developer Tools将是最好的选择。

  • 相关阅读:
    javascript--运算符
    线程池 的创建小列子,以及参数的介绍
    @SpringBootApplication注解
    SpringBoot 基础知识学习(二)——配置文件多环境配置
    springboot 配置文件读取的两种方式,以及使用到的注解解释
    用虚拟机安装了一台Linux系统,突然想克隆一台服务器,克隆后发现无法上网,如何解决?
    ---oracle 数据库的设计,PL/SQL(loop,for,if,case,while)
    xml的解析技术, 它们之间的区别?
    -----oracle优化之表分区
    --------oracle 的伪表和伪劣,简单的分页
  • 原文地址:https://www.cnblogs.com/crazycode2/p/7739871.html
Copyright © 2020-2023  润新知