React Native探索之Atom+Nuclide安装、配置和调试

前言

上一篇文章React Native探索之环境搭建与Hello World(Windows/Mac)我们搭建了开发环境,并写了个Hello World。这一节我们来学习React Native的开发IDE:Atom+Nuclide的安装、配置与调试。本文所讲的内容只适用于Mac平台。

1.开发IDE选择

React Native的开发IDE有很多种,比如FaceBook 官方推荐的 Atom+Nuclide、Android Studio的同门WebStorm(收费)、Sublime Text 3、Visual Studio Code和Deco。这里Atom+Nuclide和Deco目前并不支持Windows平台。笔者折腾了一段时间Sublime Text 3,折腾各种插件直到一脸懵逼。WebStorm和Android Studio很像,它是收费的(可以破解)。WebStorm的安装一点难度都没有,因此本篇文章主要讲Atom+Nuclide的安装。 如果你觉得Atom+Nuclide卡顿或者不好用,推荐使用WebStorm,这篇文章会帮助到你:http://blog.csdn.net/it_talk/article/details/52448597 React Native开发平台我建议使用Mac,能省不少心(开发Android我也建议用Mac来开发)。

2.准备工作

在安装Atom+Nuclide前需要先安装watchman和 flow。 watchman是 facebook 的一个开源项目,用来监视文件并且记录文件的改动情况,当文件变化时它可以触发一些操作。

brew install watchman

flow 是一个开源的JavaScript静态类型检查器,用来发现 JS 程序中的类型错误。

brew install flow

3.Atom+Nuclide安装

Atom是Github推出的一款开源编辑器,可以直接去官网https://atom.io/下载它,安装过程很简单。

安装Nuclide

接下来安装Nuclide,Nuclide是Facebook在Atom的基础上开发的一个插件IDE,可以用来开发React Native、iOS 和 Web应用。我们打开Atom,点击顶部菜单栏的Atom->Preferences,在Settings中的Install界面搜索nuclide,搜索到nuclide后点击Install按钮。如下图所示。

因为我已经安装了Nuclide,所以没有Install按钮。安装过程可能需要很长的时间,安装完毕后重新打开Atom会发现顶部菜单栏多了Nuclide一栏,说明Nuclide安装成功。

安装Nuclide相关依赖包

在Settings中点击Packages界面,点击顶部菜单栏的Packages-> Settings View->Manage Packages也能进入Packages界面。在Packages界面搜索nuclide,并点击nuclide的Settings按钮,如下图所示。

在nuclide的Settings中勾选Install Recommended Packages On Startup选项,并在Path to Flow executable输入flow 路径,flow 路径一般情况下都是:/usr/local/bin/flow,你可以在终端输入which flow 命令来进行查询。

重启 Atom,这些依赖包便会开始自动安装。

可以看到nuclide需要很多的依赖包,如果这些依赖包有哪个没有安装成功,Atom会给出提示,我们在Settings的Install界面进行搜索安装就可以了。 安装完成后会看到界面上多了一条额外的ToolBar。

配置flow

这时我们通过Add Project Folder来打开我们已有的React Native工程,如下图所示。

这时我们在终端进入React Native工程目录,执行flow语句来查看flow是否正常运行,如果发现系统的flow版本与工程配置的flow版本不一致,则打开工程中的 .flowconfig文件,查看flow的版本。

这里发现flow的版本为0.42,则在终端输入如下命令:

npm install flow-bin@0.42 -g

再次在终端输入flow,发现flow运行正常。接着在js文件的最上方加入/*@flow*/或者//@flow,这样flow就可以开始检查了。我们随便加入些错误语句来进行测试,如下图所示。

需要注意的是,网上的文章都是在index.ios.js做的测试,这是没问题的,如果在index.android.js中做测试则会发现flow不好用,这是因为在 .flowconfig文件有如下语句:

[ignore]
; We fork some components by platform
.*/*[.]android.js

所有的以.android结尾的js文件的flow检查都会失效,如果去掉该语句则会报100多个error,目前在index.android.js上笔者没有先到好的解决方案,如果有人有解决方案,不吝赐教。

4.调试程序

在终端进入项目目录并输入如下命令安装程序:

react-native run-android    

Debugger调试程序

使用快捷键 command + shift + p 打开输入框,输入debugging,并选择Nuclide React Native:Start Debugging:

这时Atom弹出Debugger界面,并等待进行Debugger。我们通过Command+M进入模拟器的开发菜单,选择Debug JS Remotely。

这时Debugger界面进入了debug状态,我们在程序中打上断点,通过按2次R键来Reload界面,程序就会停留在断点位置,如下图所示。

React Inspector

使用快捷键 command + shift + p 打开输入框,输入insp,并选择Nuclide React Inspector:Toggle:

如果连接的是SDK自带的模拟器,稍等片刻就会在React Inspector中出现如下界面,它会将当前界面的UI 层次结构显现出来。

原文发布于微信公众号 - 刘望舒(liuwangshuAndroid)

原文发表时间:2018-06-13

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏白驹过隙

Jenkins - 持续集成环境搭建

1275
来自专栏网络

Jenkins实现SpringBoot应用自动部署

工具的出现,目的就是为了提高我们的工作效率,让我们把时间花在做重要的事情上。学习本文你需要具备基本的Linux知识,学习自动部署的前提是你能够手动在服务器完成部...

3395
来自专栏运维技术迷

Shell系列-编写及执行脚本

一、第一个Shell脚本 1.什么是shell脚本? 提前写好可执行的语句,能够完成特定任务的文件(顺序执行,批量化处理;解释型程序) ? 2.shell...

3377
来自专栏前端进阶之路

git 常用操作总结

id_rsa 是私钥,id_rsa.pub 是公钥 id_rsa.pub 是你需要上传到 github 的 SSH KEY

412
来自专栏白驹过隙

Jenkins - 持续集成环境搭建

35210
来自专栏前端开发

Vue-cli脚手架快速搭建项目图文教程

“脚手架”是一种元编程的方法,用于构建基于数据库的应用。许多MVC框架都有运用这种思想。

4587
来自专栏smy

Eslint相关知识和配置大全

首先安装符合要求的node和npm版本,安装yarn(建议通过msi文件全局安装)

1343
来自专栏机器学习与自然语言处理

Linux系统常用命令总结

1. 最关键的命令 man echo 2. 目录文件操作命令 ls: 查看目录下的文件信息或文件信息 dir: pwd: 打印当前路径 cd:改变路径 mkdi...

1725
来自专栏Python爬虫与数据挖掘

在Windows下如何创建虚拟环境(默认情况下)

很多小伙伴平时在使用Python的时候,有的项目需要使用Python2来进行开发,有的项目则是需要Python3来进行开发。当不清楚怎么分开环境的时候,...

391
来自专栏云计算教程系列

如何使用Node.js和Github Webhooks保持远程项目同步

在处理具有多个开发人员的项目时,当一个人推送到存储库然后另一个人开始对过时版本的代码进行更改时,这可能会令人沮丧。像这些花费时间的错误,这使得设置脚本以保持您的...

933

扫码关注云+社区