初探React-Native

近日研究了下React-Native,一路走来真是!!!全是眼泪啊!!! 记录下走过的坑,现在把填坑方法送给大家,如果有别的问题,还请多多探讨,多多指教!

1.集成,集成我就不多说了,网上多的是我是参考这位作者的,很全面,就是有点老,要说咱就说点不一样的,首先遇到的第一个坑,创建React-Native项目语句:


//创建RN项目
react-native init NewDemo

// 创建指定RN版本的项目
react-native init NewDemo --verbose --version 0.47.0

做为一个iOS开发,我选择的是原生项目集成ReactNative,所以创建这个项目只为为了拿到他的package.josn
创建iOS项目之后 我是这么做的(打码的地方是后来的步骤,不能剧透!)


image.png

创建package.json文件,文件内容如下:name对应项目名!!!!

{
    "name": "HaTest",
    "version": "0.0.1",
    "private": true,
    "scripts": {
        "start": "node node_modules/react-native/local-cli/cli.js start",
        "test": "jest"
    },
    "dependencies": {
        "react": "16.0.0-alpha.12",
        "react-native": "0.47.0"
    },
    "devDependencies": {
        "babel-jest": "22.0.4",
        "babel-preset-react-native": "4.0.0",
        "jest": "22.0.5",
        "react-test-renderer": "16.0.0-alpha.12"
    },
    "jest": {
        "preset": "react-native"
    }
}

接下来安装React Native依赖包
在ReactComponent目录下运行命令行:

npm install

然后复制RN项目中的index.ios.js到ReactComponent目录下


image.png

其中要注意的是!!!

image.png

这三个位置一定要和项目名相同,本人最开始大意了,下面两个相同而忽略了上面那个,导致报错,报错截图就不上了,注意就行!

下一步则是要根目录下创建Podfile
Podfile文件内容为

 platform :ios, "8.0"
       use_frameworks!
       target "HaTest" do
       pod 'React', :path => './ReactComponent/node_modules/react-native', :subspecs => [
       'Core',
       'RCTActionSheet',
      'RCTGeolocation',
      'RCTImage',
      'RCTNetwork',
     'RCTPushNotification',
     'RCTSettings',
     'RCTText',
     'RCTWebSocket',
     'DevSupport',
     'BatchedBridge',
     ]
    pod "Yoga", :path => "./ReactComponent/node_modules/react-native/ReactCommon/yoga" 
    end

这是最最最正确的,这其中我走的两个坑
1.没有BatchedBridge 如果没有BatchedBridge会报错#import <fishhook/fishhook.h>这个错误,网上只有把#import <fishhook/fishhook.h>改成#import "fishhook.h"的解决方案,改成#import "fishhook.h"之后还会报错,其实是少BatchedBridge文件!

2.
image.png
这个错误其实很坑,本人试0.51RN最新版的时候是小写,在0.47版本中,Yoga就需要大写,这个你们挨个试一下就好

没问题的话应该是
image.png

下面就要开始撸代码了奥!
info.plist配置


image.png
//加载RN界面
    //真机  注意ip地址
    //    NSString * strUrl = @"http://192.168.0.122:8081/index.ios.bundle?platform=ios&dev=true";
    //本地
        NSString * strUrl = @"http://localhost:8081/index.ios.bundle?platform=ios&dev=true";
    
// props  为字典 给index.ios.js 传值,必须是字典 
    NSURL * jsCodeLocation = [NSURL URLWithString:strUrl];

    RCTRootView * rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
                                                         moduleName:@"HaTest"   
                                                  initialProperties:props
                                                      launchOptions:nil];
    
    self.view = rootView;

其中跑真机要电脑和手机联同一个wifi下 ,在运行项目前,cd到ReactComponent目录 执行react-native start


如果不运行

下面是一丢丢js的代码

index.ios.js中接收传值
加载网络图片
import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  View,
  Image,
  ListView,
  Text,
} from 'react-native';

class HaTest extends Component {


  constructor(props) {
    super(props);
    var ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
    this.state = {
      dataSource: ds.cloneWithRows(this.props.advert),
    };
  }



  render() {
    return (
      <View style={styles.container}>

      <ListView
      dataSource={this.state.dataSource}

      renderRow={this._renderRow.bind(this)}
      />         
      </View>
      )

  }
 _renderRow(rowData, sectionid, rowid) {  
    return (
      <View style={styles.itemLayout}>

      <Text>rowData.title</Text>
<Image source={{uri:rowData.imgUrl}} style={styles.imageeee} /> 

      </View>);  
}  


  }



  const styles = StyleSheet.create({
    container: {   //根View样式
      marginTop:64,
      flex: 1,
        // justifyContent: 'center',
        // alignItems: 'center',

        backgroundColor: '#63BAE0'
      },
      imageeee:{
        width:100,
        height:100,
        alignItems: 'center',
      },
      itemLayout:{  
   flex:1,  
   alignItems:'center',  
   justifyContent:'center',  

   borderColor: '#eaeaea'  
 }, 
    });


AppRegistry.registerComponent('HaTest', () => HaTest);

上面是一段ListView的代码,iOS叫TableView,其中需要注意的是 比如我想添加图片 则一定要

  AppRegistry,
  StyleSheet,
  View,
  Image,
  ListView,
  Text,
} from 'react-native';

在最上面声明一个Image,否则
image.png

你会看见可恶的红色,如果加载图片,有的图片能够加载出来,有的加载不出来,看info.plist中的App Transport Security Settings不要有Allow Arbitrary Loads in Web Content这个字段,我就是不小心添加了,所以在加载图片链接时,图片经常加载不出来

下面在来说下热更新和打包,

RN是通过加载js文件来动态获取页面的,但是在上架的时候,要打包成离线包,也就是index.ios.jsbundle文件,(index.ios.bundle也可以,还没看出他俩的区别在哪里,知道的请留言告知),千万不要向我一样,直接把js文件传服务器中然后加载,加载的是jsbundle文件!!!其次,下载,本人坑了,在下载index.ios.jsbundle文件的时候会转码,然后导致index.ios.jsbundle文件不好用了,报错Unable to execute JS call: __fbBatchedBridge is undefined
这个错是jsbundle文件有问题

,正确的做法是将index.ios.jsbundle打包成压缩包,然后下载压缩包,解压文件,就可以啦,下面说打包的方法

cd到ReactComponent目录

react-native bundle --entry-file index.ios.js  --bundle-output index.ios.jsbundle --platform ios --dev false --assets-dest
// entry-file 打包的文件名  bundle-output  输出的名字

打包之后


image.png

这个index.ios.jsbundle放在项目中加载则

 NSURL *    jsCodeLocation = [NSURL URLWithString:[[NSBundle mainBundle] pathForResource:@"index.ios.jsbundle" ofType:nil]];

基本上就是这些内容啦,其中代码和交互部分我还在研究,暂时先不写上,以免误人子弟!

还有一点是集成pushy热更官网链接 写的很详细,但是到第三步配置Bundle URL(iOS)时,找不到RCTHotUpdate.h的解决方法,参考文章

终端cd到node_modules->react-native-update路径下,执行touch react-native-update.podspec
在react-native-update.podspec这个文件中编辑

require "json"
package = JSON.parse(File.read(File.join(__dir__, "package.json")))
Pod::Spec.new do |s|
s.name = "react-native-update"
s.version = package["version"]
s.summary = "hot update for react-native"
s.author = "author (https://github.com/reactnativecn)"
s.homepage = "https://github.com/reactnativecn/react-native-pushy"
s.license = "MIT"
s.platform = :ios, "7.0"
s.source = { :git => "https://github.com/reactnativecn/react-native-pushy.git", :tag => "#{s.version}" }
s.source_files = "ios/**/*.{h,m,c}"
s.libraries = "bz2"
s.dependency "React"
end

然后在项目主Podfile添加

pod 'react-native-update' , :path => './node_modules/react-native-update'
image.png

不过我还是没意识到pushy的热更有什么用,虽然集成了,但是还没有应用,希望知道的人可以告诉下

生命不息,代码不止!码农一枚,请多点赞

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

推荐阅读更多精彩内容