(3)-窥探开发者选项
最后更新于:2022-04-01 06:49:52
> 参考文章:
> [debug](https://facebook.github.io/react-native/docs/debugging.html#content)
> [Memory leak in profile](https://github.com/facebook/react-native/issues/1452)
## react-native的开发者选项
在模拟窗口上按`Ctrl+Command+z`或者`Command+d`会调出`react native`的开发者选项:
data:image/s3,"s3://crabby-images/135ae/135ae13b8225f8685061bd2d673794ed5d59e119" alt=""
## Reload
重新运行程序,类似于在Xcode中按`Command+R`.
## Debug in Chrome
在Chrome浏览器下调试,在chrome浏览器下输入`http://localhost:8081/debugger-ui`,再按`Alt+Command+j`出现浏览器debug窗口如下:
data:image/s3,"s3://crabby-images/138f3/138f352520c1cbea046ebc4f78d6d1df67816053" alt=""
这一部分的知识属于chrome浏览器如何调试的知识,有兴趣可以单独学习。
## Debug in Safari
在Safari浏览器下调试,safari还没找到具体的事例。
## Show FPS Monitor
打开FPS监控器,如下图底部的状态栏:
data:image/s3,"s3://crabby-images/0ba85/0ba852632a923f9286edcc9c7e90abde54a35627" alt=""
## Inspect Element
可以用来查看页面中元素的结构以及属性,以及性能相关信息:
点击该选项后出现:
data:image/s3,"s3://crabby-images/a5276/a5276ac9c3c98efb6562c3e83a98aa88289c8ab5" alt=""
然后我们选择一个控件:
data:image/s3,"s3://crabby-images/668bc/668bc2e5aaad2c9c2aa28c8171934f349d374d7f" alt=""
然后选择`perf`一览,可以查看脚本下载以及执行时间(还有一个TTI是什么鬼,以后再说):
data:image/s3,"s3://crabby-images/cf46a/cf46a737bdda36fc970804e065d99e65569c5a28" alt=""
## Enable Live Reload
修改js文件后,app立即显示修改后的效果。
data:image/s3,"s3://crabby-images/dd5ba/dd5bae291825240696b551a3820302d10dae8ec1" alt=""
## Start Profiling
进行性能分析,一段时间后点击`Stop profiling`会提示如下信息:
data:image/s3,"s3://crabby-images/e3d45/e3d4527b70bac8e5ca1d745c0dfc70a58511818d" alt=""
说明我们的分析结果已经在服务器保存了,那至于这个到底分析的是什么呢?首先我们找到该文件,根据控制台输出信息:
data:image/s3,"s3://crabby-images/ed23c/ed23c2d25b8da9313f24956de44bd00bd0374537" alt=""
我们打开浏览器中输入`file://tmp`可以看到如下界面:
data:image/s3,"s3://crabby-images/2e85a/2e85a2a0cb1e8b5e99f0b347e7ee4db029b20461" alt=""
点击我们刚才保存的文件:
data:image/s3,"s3://crabby-images/f5df3/f5df3900cfff84a7ffbea2ae3cd0756c06fe1bc0" alt=""
google提供了工具[`trace-viewer`](https://github.com/google/trace-viewer)将这个json文件转化为html文件,方便我们分析数据,转化后的结果如图:
data:image/s3,"s3://crabby-images/4e11d/4e11d47c24847e345176f1a5799934a9abf18172" alt=""