RN精进笔记(二)安装以及环境配置篇

React-Native安装以及环境配置

建议使用typora打开该文档。重点参考这篇文档:http://kiwi.saylove.today/?p=124 ,下面是我自己的安装过程的总结,首先参考上面这篇文档!

  1. 安装brew

        # brew 是一个Mac下快速安装插件的工具,类似Linux的yum\apt等命令行包安装工具。安装方式
    
        $ shell
        $ ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
        $ 
        $
    
  2. 安装nvm

    brew install nvm
    

    nvm即node version manager,用来管理和支持Mac下多版本的node.js 。

    安装完后,根据终端提示,运行相关命令,即可配置相关环境变量,终端提示输入如下:

    You should create NVM's working directory if it doesn't exist:
    
    mkdir ~/.nvm
    
    Add the following to ~/.zshrc or your desired shell
    configuration file:
    
    export NVM_DIR=~/.nvm
    source $(brew --prefix nvm)/nvm.sh
    

    注意:我的一台机器使用了 oh-my-zsh。因此默认的bash是zsh,bash的配置文件是 ~/.zshrc 。使用的bash不同,配置的地方就不一样。

    注意:source 方式可能找不到nvm.sh文件,或者在主目录先找不到shell的几个配置文件 .bashrc 或者 .zshrc 等,不能直接在终端输入这些指令,否则只能在这个进程中安装了。 最后我发现需要

    vim ~/.bashrc
    vim ~/.zshrc
    vim ~/.bash_profile
    

    在系统根目录下生成这三个文件,并配置好 source /nvm.h。

    $  mkdir ~/.nvm
    $  export NVM_DIR=~/.nvm
    $  source $(brew --prefix nvm)/nvm.sh , 如果提示找不到nvm.sh,而cd到brew 目录下发现有这个文件,可以直接这么导入
    $ source /usr/local/opt/nvm.sh 
    
    
    或者:在zsh中
    #nvm load nvm
    export NVM_DIR="$HOME/.nvm"
    source $(brew --prefix nvm)/nvm.sh
    


  3. 安装最新的node

    如果用brew或者其它方式安装过node, 可以先删除node

    brew remove --force node 
    sudo rm -r /usr/local/lib/node_modules
    
    brew prune
    sudo rm -r /usr/local/include/node
    
    #检查brew是否正常
    brew doctor
    

    安装最新的node

    nvm install node 
    

    将该node设置为默认的nvm管理的node

    nvm alias default node 
    

    安装好node,其包管理工具npm, node package manager也安装好了,可以参考其包管理工具的命令。以下是npm常用指令:

    npm ls #查看当前目录下安装的包
    npm ls -g #查看全局安装的包
    npm install xxx #安装xxx包
    npm uninstall xxx
    npm info xxx 
    npm install xxx --save #安装xxx包,并将xxx依赖命令写入package.json
    npm update xxx
    
    #我的npm安装路径
    ~/.nvm/versions/node/v5.6.0/lib/node_modules/npm
    
    #nvm是用来管理node版本的工具,因此可以循该路径找到node
    #我的node执行的脚本bin
    /Users/schiller/.nvm/versions/node/v5.6.0/bin/node 
    
    #我们用react-native init myRNDemo来初始化RN项目,react-native命令的原理:
    $ cd ~/.nvm/versions/node/v5.6.0/lib/node_modules
    $ ls -a
    $ cd react-native-cli
    $ ls -a 
    .README.mdnode_modules
    ..index.jspackage.json
    
    $ vi package.json
    # package.json中有这么一段
    "bin": {  "react-native": "index.js"
    },
    $ vi index.js 
    
    if (args[0] === 'init') {
    if (args[1]) {
    init(args[1]);
    } else {
    }
    } else {
    ......
    }
    1、fs.writeFileSync(path.join(root, 'package.json'), JSON.stringify(packageJson));
    2、run('npm install --save react-native', function(e) {}
    #代码1是动态生成package.json,代码2是本地安装react-native模块。因此react native初始化项目困难,都是npm惹的祸
    

    经过上面对"react-native-cli"与“react-native”的分析,可以看出Facebook应该是推荐“react-native”模块局部化,所以不论在React Native项目初始化的过程中,还是clone已有的React Native项目,都需要在当前项目下下载和安装“react-native”模块,使得React Native 项目占用的空间越来越大。

    over

  4. 安装watchman

    brew install watchman
    

    watchman为react代码发生变化时,完成相关的重建工具,实现LiveReload功能。

  5. 安装flow

    brew install flow 
    

    flow为javasript类型检查器,实现静态类型检查

  6. 安装react-native

    npm install -g react-native-cli
    

    因为react-native 安装后需要在所有目录都可使用,因此需要全局安装-

  7. 安装nrm

    npm install -g nrm 
    nrm ls #查看有哪些可用的源地址
    nrm use taobao #使用淘宝源
    
    #也可以使用cnpm
    cnpm和淘宝源
    cnpm --- http://r.cnpmjs.org/
    

    nrm为管理node包源地址的管理器,因为node包默认为从国外服务器获取,若不更换国内源,在安装时会非常慢

  8. ​搭建私有npm,提交创建项目的速度和减少缓存

起步,RN入门教程
  1. 创建项目

    > ``` shell
    > react-native init MyReactNativeProject
    > ```
    >
    > 分析项目目录结构,node_modules为react-native依赖的相关源代码,package.json为rn依赖管理配置文件,resources为资源目录,如图片资源
    > 
    

2. 启动

> ```objective-c
> jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"];
>
> jsCodeLocation = [NSURL URLWithString:@"http://192.168.1.116:8081/index.ios.bundle?platform=ios&dev=false"];
>
> jsCodeLocation = [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
> ```
>
> 原理:
>
> ```
> 从jsCodeLocation的链接地址来看react-native是从本地端口拉取index.ios.js来执行。如果将index.ios.js的名字改为test.ios.js,然后Appdelegate.m中的index.ios.bundle改为test.ios.bundle 重新执行编译通过,验证假设。
> ```
>
> over.

3. 项目协作与迁移

> 项目协作,迁移到新的服务器必须执行`nmp install `重新更新项目的配置,否则会报错。
>
> over.
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容