React Native入门(二)Atom+Nuclide安装、配置与调试

相关文章

React Native入门

前言

上一篇文章我们搭建了开发环境,并写了个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很像,并没觉得他有什么优势可以收费(可以破解)。最终我选择了Atom+Nuclide,主要有以下几个原因:

  • 良好的代码提示功能和错误检查机制。
  • Debugger和React Inspector可以替代Chrome来进行调试工作。
  • FaceBook 官方推荐。

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 层次结构显现出来。

参考资料

Nuclide关于React Native英文文档

React Native - 开发工具Atom+Nuclide详解(安装、使用、代码调试)

学习 React Native for Android:环境搭建

React Native 开发之 IDE 选型和配置

React Native开发之IDE(Atom+Nuclide)安装,运行,调试



欢迎关注我的微信公众号,第一时间获得博客更新提醒,以及更多成体系的Android相关原创技术干货。

扫一扫下方二维码或者长按识别二维码,即可关注。

时间: 2024-10-10 07:45:16

React Native入门(二)Atom+Nuclide安装、配置与调试的相关文章

React Native入门-刘望舒

React Native入门(一)环境搭建与Hello World React Native入门(二)Atom+Nuclide安装.配置与调试 React Native入门(三)组件的Props(属性)和State(状态)

React Native 入门宝典

声明:该书的笔者为徐嬴老师,一名具有5年IOS开发经验,和两年RN开发经验的老司机. 原文可以在gitbook上找到 笔者只是为他的书中提的的一些列问题,进行有偿答疑. 有偿答疑.本书将持续保持更新,有关问题可以加群讨论. 正在上传...取消 简介 笔者在研究ReactNative过程中,发现其中文资料相对较少,已出版的大部分图书资料都已过时.Facebook中的ReactNative开发团队以每月更新一版的速度在向前推进版本. 为更好的让广大开发者快速入门ReactNative,笔者结合自身开

转 : React Native 开发之 IDE 选型和配置

转:https://mp.weixin.qq.com/s?__biz=MzA3ODg4MDk0Ng==&mid=2651112392&idx=1&sn=135e29ddde3050d469be98db815c267e&scene=0&key=18e81ac7415f67c4bcc2eaac3ca13f8d294ec1b8fa5828d4d7f13f2e81cc62f72e55e828ee04e2002284521336a3766d&ascene=0&

React Native入门(三)组件的Props(属性)和State(状态)

相关文章 React Native入门系列 前言 在Android或者iOS开发中我们会用到很多控件,这些控件会有很多的属性.样式等等.同样的,React Native中的组件也有属性.样式和状态. 1.Props(属性) 组件创建时会设置一些参数来定制这个组件,这些参数就是属性,属性一旦设定,在组件的生命周期中就不会改变.下面拿Image的source属性和Text的onPress属性作为举例. Image的source属性 import React, {Component} from 're

React Native 入门基础知识总结

中秋在家闲得无事,想着做点啥,后来想想,为啥不学学 react native.在学习 React Native 时, 需要对前端(HTML,CSS,JavaScript)知识有所了解.对于JS,可以看看阮一峰老师的<ECMAScript 6 入门>这篇文章.里面涉及很多 ES6 的新特性.我之前也是看了阮老师的文章做了一些学习笔记 ES6 学习笔记. 1.环境搭建 环境搭建中文教程,点击跳转RN中文社区 :http://reactnative.cn/docs/0.40/getting-star

React Native入门(一)环境搭建与Hello World

前言 目前关于React Native的教程很多,官方文档写的也不错,但是感觉大部分教程写的不是很清楚,导致我各种碰壁.因此我来写一个简洁的教程.本篇文章基于React Native 0.43,只适用于用Windows平台的Android开发者. 1.配置React Native 首先我们要先来安装一些软件,如下所示. Chocolatey Chocolatey是一个Windows上的命令行包管理器,安装了Chocolatey就可以通过命令行来安装一些我们需要软件.我们打开cmd命令行程序使用如

React Native入门-实战解析(上)

来自Leo的原创博客,转载请著名出处 我的stackoverflow 概述 随着app端越来越复杂,迭代越来越快,很多app采用原生+html5的方式来实现,然后不知道什么时候,它就有了个高大上的名字 - hybrid app.类似的框架也很多,比较有名的有 Ionic PhoneGap 这种app的原理是,用webview来实现类似原生的界面,也就是用h5写的代码是运行在webview里的.优点很明显 动态部署(不需要每次通过应用商店的审核,尤其是iOS,审核有时候真的觉得两颗蛋不够疼的.)

react native 入门 (1)- 环境搭建, 创建第一个Hello World

Create React Native App 是开始构建新的React Native应用程序的最简单方法.它允许您启动项目而无需安装或配置任何工具来构建本机代码 - 无需安装Xcode或Android Studio. 先安装Node.Js,则可以使用npm来安装create-react-native-app命令行实用程序: (NPM的全称是Node Package Manager,是一个NodeJS包管理和分发工具,已经成为了非官方的发布Node模块(包)的标准), npm install -

React Native - 1 Windows下的环境配置(Windows+Android)

参考:https://facebook.github.io/react-native/docs/getting-started.html(要FQ) 网站上建议使用Chocolatey去配环境,不过这个站点在国内访问太慢了,所以我们单独安装下面的软件就好了. 1. 安装Node.js: https://nodejs.org/en/,下载安装最新版本(推荐LTS版本) 确认Node.js是否安装成功,cmd里输入:node -v (退出是按两次 ctrl+c) 2. 安装python2,https: