React-Native简介

React-Native 基于目前React来开发IOS原生应用,Android版本将在年底推出。

为什么需要React-Native

目前主流的应用大体分成三类:Native App, Web App, Hybrid App.

Native App

优点

  • 性能好,性能好,还是性能好 缺点
  • 开发成本高,无法跨平台
  • 升级困难
Web App

优点

  • 跨平台,Write Once , Run Anywhere
  • 版本升级容易 缺点
  • 无法系统系统级的API
  • 临时入口,用户留存度低
  • 性能差
Hybrid App

Native App 和 Web App 折中的方案,保留了 Native App 和 Web App 的优点。但是最受吐槽的还是性能差。页面渲染效率低,在Webview中绘制界面,实现动画,资源消耗都比较大。

React-Native

What we really want is the user experience of the native mobile platforms, combined with the developer experience we have when building with React on the web.

这是 React-Native 设计的初衷: 既保留流畅的用户体验,有保留React的开发效率

React-Native 做了什么

  • React-Native 丢弃了 Webview。
  • 复用React,将 Dom 结构de改变通过 diff 算法处理后,由 js 传递给 native 进行底层视图布局。
  • css-layout引擎,前端可以继续写熟悉的 css 语法,由引擎转化成 oc 底层的布局。
  • 对 js 暴露底层常用的 UI 组建。js 层可以直接对这些组件进行布局。

对应前端的开发模式的变化:

  • JSX vs Html
  • css-layout vs css
  • ECMAScript 6 vs ECMAScript 5
  • React-Native vs DOM

如何开始

1) 安装以来的包和软件,参考这里。 2) 运行下面的命令,初始化项目:

react-native init helloworld

3) 在项目目录下面,运行:

    npm install
    npm start

4) 使用 Xcode 开发项目,运行,即可看到模拟器中的效果。这里有可能会运行失败报错,主要可以从2方面排查:

  • AppDelegate.m 中 jsCodeLocation 的定义是否正确。
  • 删除 /Users/{you}/Library/Developer/Xcode/DerivedData 文件夹,重启Xcode。 (PS: 官方给的例子好几个都有上面的问题,跑不起来)

5) 修改目录下的 index.ios.js 文件,定制自己的UI。

    render : function() {    
        return (
            <View style={styles.container}>
            <Text>Hello World!</Text>
            </View>

        )
    }

cmd + R 刷新模拟器即可看到效果,就是这么简单。

进阶玩法,自定义UI组件

如下图,实现课程列表的效果(下图是react-native实现效果,原效果猛戳这里,只实现了页面中的listview):

    var CList = React.createClass({
    getInitialState: function(){
        var ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
        return {
            dataSource: ds.cloneWithRows(data),
            load: false
        }
    },    
    render: function(){
        return (
            <ListView dataSource={this.state.dataSource} 
            renderRow={this.renderRow} 
            style={styles.courseList} />
        )    
    },
    renderRow: function(course){
        course._price = course.price == 0 ? '免费' : '¥' + (course.price / 100).toFixed(2);
        course._priceCla = {};
        course._priceCla.color = course.price == 0 ? '#5db61b' : '#e85308';
        return(
            <TouchableOpacity>
                <View style={styles.row}>
                    <View style={styles.container}>
                        <Image style={styles.face} source={{uri : course.cover_url + '222'}}/>
                        <View style={styles.right}>
                            <Text style={styles.name} numberOfLines="2">{course.name}</Text>
                            <Text style={styles.agency}>{course.agency_name}</Text>
                            <View style={{flex: 1, flexDirection: 'row'}}>
                            <Text style={[styles.price,course._priceCla]}>                        
                            {course._price}
                            </Text>
                            <Text style={{color: 'gray', flex: 1}}>{course.see_num}人观看</Text>
                            </View>
                        </View>
                    </View>
                </View>
            </TouchableOpacity>
        )
    }
});
module.exports = CList;

在入口文件中,require上面的文件,然后在render方法中直接调用改组件即可。

  render: function() {
    return (
        <NavigatorIOS
            style={styles.container}
            initialRoute={{
                title: '课程列表',
                component: CList,
            }} />
    );
  }

总结

小试了一下 React-Native,还是很强大的,期待Android的版本。文章中若有不对,欢迎斧正、交流。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小白鼠

Ionic3 高德Web定位

高德提供了Web平台定位的JS API,同样需要用到 APP_Key,并且需要注意是使用Web端的Key,如下图所示。必须是Web端的,其它平台的无效。 ht...

17820
来自专栏前端儿

Web--CSS控制页面(link与import方式区别)

【1】         “Table”和“DIV”这两个网页元素诞生的目的不同,首先Table诞生的目的是为了存储数据,而DIV诞生的目的就是为了架设页面结构

16310
来自专栏互联网开发者交流社区

AngularJS基础

11820
来自专栏司想君

HTML5.2新特性解读

不到一个月之前,W3C官方发布 HTML5.2,并成为官方推荐使用标准。这意味着作为web开发者,我们可以愉快地使用5.2中的新特性了。 W3C在HTML5.2...

37550
来自专栏葡萄城控件技术团队

Spread for Windows Forms快速入门(16)---用Spread设计器创建和编辑图表

Spread支持85种丰富多彩的图表效果。可以在Spread设计器中基于工作表的数据直接生成图表,操作简单。同时,软件人员还可以在Visual Studio设计...

23780
来自专栏前端知识分享

第176天:页面优化

从用户角度而言,优化能够让页面加载得更快、对用户的操作响应得更及时,能够给用户提供更为友好的体验。从服务商角度而言,优化能够减少页面请求数、或者减小请求所占带宽...

13420
来自专栏非著名程序员

拖拽,自由组合,让你的开发更加简单,用户更方便

今天给大家推荐一个自由拖拽,自由组合的控件,这个控件是我自定义写的。通过它,我们可以自由拖拽,自由组合实现一个界面,满足一个用户自由组合界面的需求。这里不是通过...

24560
来自专栏大数据钻研

前端面试那些坑之HTML篇

HTML 1、Doctype作用?标准模式与兼容模式各有什么区别? (1)、<!DOCTYPE>声明位于位于HTML文档中的第一行,处于<html> 标签之前...

40590
来自专栏Puppeteer学习

使用puppeteer抓取受限网站

不要相信前端是安全的,今天简单验证一下(但是希望大家支持正版,支持原作者,毕竟写书不易)。

666130
来自专栏Jerry的SAP技术分享

微信小程序开发系列六:微信框架API的调用

通过前面五个章节的介绍,大家对微信小程序的视图和控制器,微信调试器,以及如何在微信控制器里编写JavaScript函数来响应微信小程序的用户事件已经有了一个最基...

41920

扫码关注云+社区

领取腾讯云代金券