向原有項(xiàng)目中集成React-Native

之前的文章中講解Node以及React的基本知識疾忍,本文就著重講一下如何向現(xiàn)有項(xiàng)目中集成React-Native企孩。
眾所周知袁稽,我們集成React-Native的目的是在本地編輯JS文件即可實(shí)現(xiàn)多端并用(比如iOS、Android等)补疑。而JS文件即是通過React-Native的某個方法加載的。我們不妨看一下最終在我們本地項(xiàng)目中加載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的文件來實(shí)現(xiàn)加載指定的JS文件锹杈。當(dāng)然,這里的RCTRootView就是我們需要導(dǎo)入的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前執(zhí)行npm install即可岗照。
講解了原理笆环,這里我們把步驟詳細(xì)描述一遍。

以我們的Shop項(xiàng)目為例
1.在Shop目錄下創(chuàng)建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.運(yùn)行命令npm install命令迫吐。這樣就創(chuàng)建了node_modules目錄账忘,并包含了React—Native等三方庫熙宇。

3.在Podfile中添加React-Native依賴溉浙,并執(zhí)行pod update命令
4.在項(xiàng)目的某個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. 在項(xiàng)目根目錄中創(chuàng)建文件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: '企業(yè)資料', icon:'./img/icon.png', title: ''},
                {key: '優(yōu)質(zhì)物流包月', 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
  },
})

//  項(xiàng)目名要有所對應(yīng)
AppRegistry.registerComponent('Shop', () => Shop);

6.在項(xiàng)目根目錄中執(zhí)行npm start命令。即可看到如下頁面:

效果圖

參考

npm 與 package.json 快速入門教程

ios原生項(xiàng)目集成reactnative步驟(RN學(xué)習(xí)一)

在iOS中創(chuàng)建React-Native頁面吨铸,并跳轉(zhuǎn)到原生頁面

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末诞吱,一起剝皮案震驚了整個濱河市竭缝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌抬纸,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阿趁,死亡現(xiàn)場離奇詭異脖阵,居然都是意外死亡墅茉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門悍募,熙熙樓的掌柜王于貴愁眉苦臉地迎上來洋机,“玉大人,你說我怎么就攤上這事绷旗∮巧瑁” “怎么了颠通?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵顿锰,是天一觀的道長启搂。 經(jīng)常有香客問我,道長牢撼,這世上最難降的妖魔是什么疑苫? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮撼短,結(jié)果婚禮上挺勿,老公的妹妹穿的比我還像新娘。我一直安慰自己不瓶,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著麦备,像睡著了一般。 火紅的嫁衣襯著肌膚如雪弄屡。 梳的紋絲不亂的頭發(fā)上鞋诗,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天,我揣著相機(jī)與錄音全庸,去河邊找鬼。 笑死壶笼,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的保礼。 我是一名探鬼主播责语,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼坤候,長吁一口氣:“原來是場噩夢啊……” “哼胁赢!你這毒婦竟也來了白筹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤吹害,失蹤者是張志新(化名)和其女友劉穎它呀,沒想到半個月后棒厘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谓媒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年何乎,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抢野。...
    茶點(diǎn)故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡各墨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出恃轩,到底是詐尸還是另有隱情,我是刑警寧澤叉跛,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布筷厘,位于F島的核電站,受9級特大地震影響敞掘,放射性物質(zhì)發(fā)生泄漏楣铁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一赫冬、第九天 我趴在偏房一處隱蔽的房頂上張望溃列。 院中可真熱鬧,春花似錦补鼻、人聲如沸雅任。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至寇漫,卻和暖如春殉摔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背逸月。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工彻采, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留捌归,地道東北人岭粤。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像巾兆,于是被迫代替她去往敵國和親虎囚。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 開發(fā)平臺:macOS 搭建開發(fā)環(huán)境 必需軟件 Homebrew, Mac系統(tǒng)的包管理器圃伶,用于安裝NodeJS和一些...
    MichaelLedger閱讀 4,752評論 0 3
  • 盡管在移動開發(fā)中,原生APP的開發(fā)成本很高,但現(xiàn)階段基于原生開發(fā)仍然是必須的,因?yàn)閃eb的用戶體驗(yàn)仍無法超越Nat...
    奔跑的大橙子閱讀 5,398評論 0 11
  • 如果我們認(rèn)真的去寫日記窒朋,就會發(fā)現(xiàn)蝗岖,今日的信息量,蠻大抵赢。 我們是否有深入的品質(zhì)。 一段深入的關(guān)系杰标? 一件能做深入的事...
    顯彈閱讀 181評論 0 0
  • "老板掸犬,來個煎餅绪爸。" "好勒湾碎,這里掃微信奠货。"現(xiàn)如今的app,你沒個微信支付寶支付柔滔,怎么好意思說自己公司能盈利。大...
    奔跑吧李博閱讀 585評論 1 25
  • 如果你不是官二代形真,富二代超全,不是一畢業(yè)就有早已準(zhǔn)備好的工作讓你前去入職,那么嘶朱,我作為過來人,作為畢業(yè)了的疏遏,踏入過職場...
    妍兮閱讀 1,168評論 51 53