react native 探索(一)

为什么使用react native?

既拥有Native的用户体验、又保留React的开发效率。——引自React Native的发布稿
react native通过一次编写可以在IOS和Android设备上运行。这样可以为公司节约成本,使代码更好维护。(不用再招2大客户端的程序员、代码也不需要维护2套,但现在还有一些组件是属于IOS或者Android专有的所以请尽量选择使用那些用JavaScript编写的组件)。只要熟悉web开发,就可以成为潜在的客户端开发者。使用单一的JavaScript库就能写出真正的原生的iOS和Android的应用来。当然学习react时需要理解其中的概念,还是有些时间成本。那么什么又是react native呢?请往下看。

什么是react native?

Facebook在2015年发布了react native的第一个版本。可以基于目前大热的开源JavaScript库React.js来开发iOS和Android原生App。只要编写一次,能在任何手机端上跑。

  • Build Native Mobile Apps using JavaScript and React。
    react native 仅仅使用JavaScript就能让你编写一个原生的手机App。使用起来有点像React,让你使用组件式的形式编写手机App。
    它看起来像下面这个样子。

     import React, { Component } from 'react';
     import { Text, View } from 'react-native';
     class WhyReactNativeIsSoGreat extends Component {
     render() {
        return (
          <View>
            <Text>
              If you like React on the web, you'll like React Native.
            </Text>
            <Text>
              You just use native components like 'View' and 'Text',
              instead of web components like 'div' and 'span'.
            </Text>
          </View>
         );
        }  
      }
    
  • 使用react native编写的app是一个真的手机App
    使用react native,你不用编写一个“mobile web app”或者 “HTML5 app”,你所编写的App都是从 Objective-C 或者 Java原生而来。react native使用一些基本的UI组件去构成IOS和Android的App。你只需使用JavaScript 和 react把这些组件组装在一起。
    例如像下面这样一个例子,创建了一个可滑动的视图。
    import React, { Component } from 'react';
    import { Image, ScrollView, Text } from 'react-native';

      class AwkwardScrollingImageWithText extends Component {
        render() {
          return (
              <ScrollView>
                <Image source={{uri: 'https://i.chzbgr.com/full/7345954048/h7E2C65F9/'}} />
                <Text>
                  On iOS, a React Native ScrollView uses a native UIScrollView.
                  On Android, it uses a native ScrollView.
    
                  On iOS, a React Native Image uses a native UIImageView.
                  On Android, it uses a native ImageView.
    
                  React Native wraps the fundamental native components, giving you
                  the performance of a native app, plus the clean design of React.
                </Text>
              </ScrollView>
          );
        }
      }
    
  • 不要把时间浪费到重新编译上
    react native能让你快速的编写一个app,在重新编译这块,你可以立刻看到看到你修改的效果。使用热重载技术,你甚至可以在运行新的代码,并且保留应用的状态。

    热重载技术

  • 需要时可以使用原生的代码
    react native可以毫不费力的,与Objective-C、java、swift写的原生组件桥接起来。
    import React, { Component } from 'react';
    import { Text, View } from 'react-native';
    import { TheGreatestComponentInTheWorld } from './your-native-code';

      class SomethingFast extends Component {
        render() {
          return (
              <View>
                <TheGreatestComponentInTheWorld />
                <Text>
                  TheGreatestComponentInTheWorld could use native Objective-C,
                  Java, or Swift - the product development process is the same.
                </Text>
              </View>
          );
        }
      }
    

如何初始化你的第一个react native项目

由于操作系统的原因,和环境的问题,暂时演示,IOS App的初始化

  • 需要node.js, React Native 命令行工具和Watchman
    推荐使用Homebrew安装node.js和Watchman。

brew install node
brew install watchman

  • 使用npm安装 React Native 命令行工具接口

npm install -g react-native-cli

  • 测试安装react native项目
    使用react native命令行工具生成一个新的react native项目,命名为MyFirstRNApp,然后进入项目的根目录,运行react-native run-iso命令

react-native init MyFirstRNApp
cd MyFirstRNApp
react-native run-ios

  • react-native init MyFirstRNApp

    初始化中的MyFirstRNApp

    初始化MyFirstRNApp成功

  • react-native run-ios

    编译中

    编译成功后弹出,react native控制台页面

    第一个react native项目页面

react native项目结构介绍

在项目根目录下有3个文件夹,2个js文件,一个json文件

  • 文件夹 android
    主要存放关于项目android的文件
  • 文件夹 ios
    主要存放关于项目ios的文件
  • 文件夹 node_modules
    存放的是一些项目依赖包
  • index.android.js
    为安卓 app的入口文件
  • index.ios.js
    为iOS app的入口文件
  • package.json
    为该项目依赖包的管理文件
react native项目结构图
  • index.ios.js 入口文件解析
    /**
    * Sample React Native App
    * https://github.com/facebook/react-native
    * @flow
    */

      //es6的语法格式
      import React, { Component } from 'react';
      import {
        AppRegistry, //入口文件必备,提供整个app组件注册的功能
        StyleSheet, //样式表
        Text, //react native 提供的组件 Text
        View  //react native 提供的组件 View
      } from 'react-native';
    
      //js的类文件
      class MyFirstApp extends Component {
    
        //渲染返回包装好的组件
        render() {
          //返回包装好的组件
          return (
            <View style={styles.container}> /*相当于div*/
              <Text style={styles.welcome}>
                Welcome to React Native!
              </Text>
              <Text style={styles.instructions}>
                To get started, edit index.ios.js
              </Text>
              <Text style={styles.instructions}>
                Press Cmd+R to reload,{'\n'}
                Cmd+D or shake for dev menu
              </Text>
            </View>
          );
        }
      }
    
      //样式表文件
      const styles = StyleSheet.create({
        container: {
          flex: 1,
          justifyContent: 'center',
          alignItems: 'center',
          backgroundColor: '#F5FCFF',
        },
        welcome: {
          fontSize: 20,
          textAlign: 'center',
          margin: 10,
        },
        instructions: {
          textAlign: 'center',
          color: '#333333',
          marginBottom: 5,
        },
      });
    
      AppRegistry.registerComponent('MyFirstApp', () => MyFirstApp);
    

以上这就是使用JavaScript和react构建的一个原始App的代码,很简单吧。

浅析react native架构

react native 架构
  • 1.在不同平台上使用js和jsx语法编写react代码,js解释器可以在不同平台运行。
  • 2.通过虚拟DOM更新和刷新状态进行对组件的重新渲染
  • 3.将结果展示到不同的终端

jsx

jsx是JavaScript的语法延伸,看起来像XML结构。目前react native支持ES6的语法。

虚拟DOM

React中的DOM并不保证马上影响真实的DOM,react会等到事件循环结束,利用diff算法,通过当前新DOM树与之前的DOM树作比较,计算出最小的步骤更新真实的DOM。这样做的好处是性能得到了很大的保证。

总结

本文对react native是什么,能做什么,做了一个大致的了解,并创建了一个全新的react native项目并成功编译运行,了解了项目中的结构,和接口文件中的内容。浅析了react native架构,理解了LEARN ONCE, WRITE ANYWHERE的道理。简单阐述了,当前版本所支持的语法版本,和解释什么是虚拟DOM,和它的作用。

成熟案例

https://facebook.github.io/react-native/showcase.html

参考

https://facebook.github.io/react-native/docs/getting-started.html

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

推荐阅读更多精彩内容