RN集成,react native集成到现有iOS项目中

RN集成到现有项目中

preivew

本片文章主要适用于iOS开发者。

安装环境

1、node.js

brew install node
brew install watchman

2、npm换源

中国站明确提醒,切勿用cnpm

npm config set registry https://registry.npm.taobao.org --global
npm config set disturl https://npm.taobao.org/dist --global

3、可选择的安装yarn

npm install -g yarn react-native-cli

4、yarn换源

yarn config set registry https://registry.npm.taobao.org --global
yarn config set disturl https://npm.taobao.org/dist --global

5、yarn和npm简单区别

yarn add xxx,npm install xxx

6、安装xcode以及comman line tools,作为iOS开发的同学这个如果不会,建议放弃程序员职业

7、在集成到现有iOS项目之前,先跑通一遍由RN脚手架创建的独立工程。

#用react-native工具创建helloword项目
react-native init AwesomeProject --version 0.55.4
#进入工程目录
cd AwesomeProject
#安装npm依赖,这个过程可能会很漫长,有一些库很大,建议科学上网。
npm install
#起服务,这个命令会唤起iOS模拟器
react-native run-ios
#作为iOS开发者,你也可以这样
npm start
#然后打开iOS工程,用xcode编译运行

官网也给出了链接解决

国内上网难,解决办法

8、不出意外,应该会正常展示一个helloword页面,当然也会有意外,遇到意外可以留言,会给与解答。

集成现有iOS项目

1、在项目根目录创建文件名为:package.json的文件,start是启动服务命令,即npm start,bundle-ios是打包命令,即npm bundle-ios会在./ios/bundle目录下面生产js,这个js会在后面的didFinishLaunchingWithOptions中使用,前提是你得有这个./ios/bundle目录。

2、内容如下

{
  "name": "MyReactNativeApp",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node node_modules/react-native/local-cli/cli.js start",
    "bundle-ios": "node node_modules/react-native/local-cli/cli.js bundle --entry-file index.js  --platform ios --dev false --bundle-output ./ios/bundle/index.jsbundle --assets-dest ./ios/bundle",

  }
}

3、命令行cd到package.json所在的文件夹,安装npm依赖

yarn add react-native@0.55.4
#亲测,其他很多版本有问题,会导致iOS工程编译不通过,或者编译通过运行crash

4、这时候可能会提示,缺少依赖包,咱们一个一个安装

warning "react-native@0.52.2" has unmet peer dependency "react@16.2.0".

会有类似的warnings提示,不可忽略,依葫芦画瓢,如果是如上提示,那么
yarn add react@16.2.0
知道warnings消失

5、安装cocoaPods,如果你没有,作为iOS开发的同学,建议放弃程序员职业

6、怎么安装、初始化pod不累赘

target 'NumberTileGame' do
  # 'node_modules'目录一般位于根目录中
  # 但是如果你的结构不同,那你就要根据实际路径修改下面的`:path`
  pod 'React', :path => '../node_modules/react-native', :subspecs => [
    'Core',
    'CxxBridge', # 如果RN版本 >= 0.47则加入此行
    'DevSupport', # 如果RN版本 >= 0.43,则需要加入此行才能开启开发者菜单
    'RCTText',
    'RCTNetwork',
    'RCTWebSocket', # 调试功能需要此模块
    'RCTAnimation', # FlatList和原生动画功能需要此模块
    # 在这里继续添加你所需要的其他RN模块
  ]
  # 如果你的RN版本 >= 0.42.0,则加入下面这行
  pod 'yoga', :path => '../node_modules/react-native/ReactCommon/yoga'

  # 如果RN版本 >= 0.45则加入下面三个第三方编译依赖
  pod 'DoubleConversion', :podspec => '../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec'
  pod 'glog', :podspec => '../node_modules/react-native/third-party-podspecs/glog.podspec'
  pod 'Folly', :podspec => '../node_modules/react-native/third-party-podspecs/Folly.podspec'

end

Podfile里面,可以看到很多pod都是依赖于本地路径的,要确保这些路径能真实访问到

7、pod install

这个过程漫长,很漫长,请科学上网,发现失败不要放弃,继续重试

8、到这里从开发环境角度已经搭建完成了,咱们就写一个RN页面,名字叫index.js,同样放到根目录下去

/**
 * Sample React Native App
 * https://github.com/facebook/react-native
 *
 * @format
 * @flow
 */

import React, { Component } from 'react';
import {
  Platform,
  StyleSheet, Text
} from 'react-native';

const instructions = Platform.select({
  ios: 'Press Cmd+R to reload,\n' + 'Cmd+D or shake for dev menu',
  android:
    'Double tap R on your keyboard to reload,\n' +
    'Shake or press menu button for dev menu',
});

// type Props = {};
export default class App extends Component {
  constructor(props) {
    super(props);
    this.state = {
      hello : 'Hello Suning'
    };
  }
  render() {
    let title = this.state.hello;
    return (
      <Text style={styles.text}>{title}</Text>
    );
  }
}
const styles = StyleSheet.create({
  
  text: {
    width: 100,
    height: 100,
    fontWeight: 'bold',
    backgroundColor: '#8ab9c2',
    flex: 1,
    color: 'red'
  }
});

9、iOS集成RN,配置初始化代码

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    //第一种方式:系统API
//    NSURL *jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
    //第二种方式,制定url
        NSURL *jsCodeLocation = [NSURL URLWithString:@"http://127.0.0.1:8081/index.bundle?platform=ios"];
//    第三种方式 npm run bundle-ios
//    NSURL *jsCodeLocation = [[NSBundle mainBundle] URLForResource:@"bundle/index" withExtension:@"jsbundle"];
    RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
                                                        moduleName:@"SMINIP"
                                                 initialProperties:nil
                                                     launchOptions:launchOptions];
    rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
    
    self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
    UIViewController *rootViewController = [UIViewController new];
    rootViewController.view = rootView;
    self.window.rootViewController = rootViewController;
    [self.window makeKeyAndVisible];
    
    return YES;
}

验证url是否可用

浏览器打开此链接,如果看到的是一大坨js,那就对了。再次过程中,请确保npm start了。

10、三种方式说明,

第一种,系统的api,应该RN会自动找服务中的index页面

第二种,指定url

第三种,指定js文件,

大家可能会疑惑,为什么要npm start起一个服务?是因为我们【8】中写的那个index.js是不能直接运行的,需要

链接很多js库,打包一起才能运行。所以这个服务就是起到这个作用,你把从服务中获取url,换成第三种方式-使用js文件作为RN加载就不难理解了。

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

推荐阅读更多精彩内容