向原有项目中集成React-Native

之前的文章中讲解Node以及React的基本知识,本文就着重讲一下如何向现有项目中集成React-Native。
众所周知,我们集成React-Native的目的是在本地编辑JS文件即可实现多端并用(比如iOS、Android等)。而JS文件即是通过React-Native的某个方法加载的。我们不妨看一下最终在我们本地项目中加载JS文件的代码:

NSString * strUrl = @"http://localhost:8081/index.bundle?platform=ios&dev=true";
NSURL * jsCodeLocation = [NSURL URLWithString:strUrl];
RCTRootView * rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation moduleName:@"Shop" initialProperties:nil launchOptions:nil];
rootView.frame = self.view.bounds;
rootView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
[self.view addSubview:rootView];

这是我们在某个ViewController的ViewDidLoad方法中加载JS文件所使用的方法,大概意思就是通过加载URL地址为:http://localhost:8081/index.bundle?platform=ios&dev=true的文件来实现加载指定的JS文件。当然,这里的RCTRootView就是我们需要导入的React-Native库文件中包含的类。

既然我们依赖React-Native库,那就需要在PodFile中指定,这里我们指定如下:

pod 'React', :path => './node_modules/react-native', :subspecs => [
    'Core',
    'RCTText’,
    'RCTImage',
    'RCTNetwork',
    'RCTWebSocket',
    'DevSupport',
    'CxxBridge',
    ]
pod "yoga", :path => './node_modules/react-native/ReactCommon/yoga'

我们可以看到,这里有两个库Reactyoga。并且这两个库的路径都在本地的node_modules目录下。
node_modules是什么目录呢,毫无疑问,npm的依赖库目录就是它。因此我们只需要在pod install前执行npm install即可。
讲解了原理,这里我们把步骤详细描述一遍。

以我们的Shop项目为例
1.在Shop目录下创建package.json文件

{
  "name": "shop",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node node_modules/react-native/local-cli/cli.js start",
    "test": "jest"
  },
  "dependencies": {
    "react": "^16.3.0-alpha.1",
    "react-native": "0.54.2",
    "uuid": "^3.2.1"
  },
  "devDependencies": {
    "babel-jest": "23.0.0-alpha.0",
    "babel-preset-react-native": "4.0.0",
    "jest": "22.4.2",
    "react-test-renderer": "^16.3.0-alpha.1"
  },
  "jest": {
    "preset": "react-native"
  }
}

2.运行命令npm install命令。这样就创建了node_modules目录,并包含了React—Native等三方库。

3.在Podfile中添加React-Native依赖,并执行pod update命令
4.在项目的某个ViewController的ViewDidLoad中添加代码,用于引入React—Native

NSString * strUrl = @"http://localhost:8081/index.bundle?platform=ios&dev=true";
NSURL * jsCodeLocation = [NSURL URLWithString:strUrl];
RCTRootView * rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation moduleName:@"Shop" initialProperties:nil launchOptions:nil];
rootView.frame = self.view.bounds;
rootView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
[self.view addSubview:rootView];
  1. 在项目根目录中创建文件index.js,并输入以下代码:
import React, { Component } from 'react';
import {AppRegistry,Text,View,FlatList,StyleSheet, Image } from 'react-native';

class Shop extends Component {
  render() {
    return (
        <View style={styles.container}>
            <View style={styles.top}>
                   <Text style={styles.topText}>iOS提交资料</Text>
                   <Text>13312345678</Text>
            </View>

            <FlatList style={styles.list}
              data={[
                {key: '会员中心', icon:'./img/icon.png', title: '普通商家'},
                {key: '企业资料', icon:'./img/icon.png', title: ''},
                {key: '优质物流包月', icon: './img/icon.png', title: '已开通'},
                {key: '修改登录密码', icon: './img/icon.png', title: ''},
              ]}
              renderItem={({item}) => 
              <View style={styles.item}>
                <View style={styles.itemLeft}>
                    <Image source={require('./img/icon.png')} style={styles.leftIcon} />
                    <Text style={styles.itemText}>{item.key}</Text>
                </View>
                <View style={styles.itemRight}>
                    {item.title && <Text>{item.title}</Text>}
                    <Image source={require('./img/rightarrow.png')} style={styles.rightIcon}  />
                </View>
              </View>
          }
            />
      </View>

    );
  }
}

const styles = StyleSheet.create({
  container: {
    position: 'relative',
    top: 50,
        paddingLeft: 15,
        paddingRight: 15,
  },

  top: {
    position: 'relative',
    top: 10,
        left: 145,
    },
    topText: {
        fontWeight: 'bold',
        fontSize: 18,
        marginBottom:6
    },
  list: {
    position: 'relative',
    top: 100,
        left: 0,
  },
  item: {
    position: 'relative',
        flexDirection: 'row',
        justifyContent: 'space-between',
        alignItems: 'center',
        height:55,
  },
  leftIcon:{
    width: 20,
        height: 20,
  },
  itemText: {
        textAlign: 'center',
        left:10,
        top:4,
        fontSize: 14,
  },
  itemLeft: {
    flexDirection: 'row',
  },
  itemRight: {
    flexDirection: 'row',
    },
    rightIcon:{
    width: 10,
        height: 10,
        marginLeft:8,
        marginRight:8
  },
})

//  项目名要有所对应
AppRegistry.registerComponent('Shop', () => Shop);

6.在项目根目录中执行npm start命令。即可看到如下页面:

效果图

参考

npm 与 package.json 快速入门教程

ios原生项目集成reactnative步骤(RN学习一)

在iOS中创建React-Native页面,并跳转到原生页面

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

推荐阅读更多精彩内容