声明:本文CSDN作者原创投稿文章,未经许可禁止任何形式的转载。
编者:本文来自携程框架研发部高级经理魏晓军在第二期【携程技术微分享】上的分享,以下为整理后的文字实录。关注携程技术中心微信公号ctriptech,可获知更多微分享课程信息。
责编:钱曙光,关注架构和算法领域,寻求报道或者投稿请发邮件qianshg@csdn.net,另有「CSDN 高级架构师群」,内有诸多知名互联网公司的大牛架构师,欢迎架构师加微信qshuguang2008申请入群,备注姓名+公司+职位。

因为支持用javascript开发原生应用,React Native一推出就受到不少公司热捧,各家都跃跃欲试。但有一个痛点是,在移动端,我们是否有必要开发多套程序:iOS、Android和H5?本次将通过对Moles框架的分享,介绍携程在React Native方面的实战干货,希望给大家一些灵感和启发。

本次分享的内容包括三个方面:

  1. Moles框架在React Native和我们主App的集成中起到了什么作用?
  2. Moles框架是如何打通Android、iOS、H5、SEO,让我们一套代码跑在多个平台上
  3. Moles框架的组成以及原理是怎样的?

这些内容将通过以下几个部分的讲解来一一给大家进行解答:

  • React Native的现状
  • Moles 框架的出现
  • Moles 框架的组成
  • Moles 框架的功能
  • Moles 框架的原理简析
  • Moles 框架的使用
  • Moles 框架的案例
  • 开源计划。

一、React Native的现状

React Native是2015年3月份Facebook开源的一个Native上的一个框架。那么为什么它现在会这么火呢。

我们先来看看它有什么优点:

首先,对于做前端的我来说,最吸引的就是可以用javascript来开发Native应用了。之前javascript只可以开发浏览器上的一些功能,随着Node.js的出现,又让javascript走向了服务端,现在React Native的出现又让javascript走向了Native端。如果要用现在一个时髦的词来形容javascript的话,我觉得“全栈”真的不为过。

其次,React Native是Facebook将ReactJS的思想移植到Native端。所以React Native就拥有了RectJS的很多特性,如:组件化思想、Virtual Dom技术以及JSX与Flexbox组合完成的布局等等,同时React Native又引入了热更新机制、CssLayout机制,让开发人员尤其是Native开发人员眼前一亮。

有优点也有缺点,我们再来看看它的不足:

我们知道React Native先出了iOS版本,然后出了Android版本。两个版本之间存在很多的差异性,甚至有好多组件都会带有平台的后缀,这使得开发人员必须要为这两个平台写不同的代码。

此外,对于公司来说,在移动上的投入,不仅有Native还会有H5,而在H5上React Native并没有考虑。从MVC框架的角度来看,React Native只做了View这一层,那么Controller、Model、Router还需要做。从App的完整性来看,只学会React Native并不能开发一个健全的App。它的更新策略、Hybrid API的提供,配套的UI组件、监控机制等等这些都没有。

二、Moles 框架的出现

伴随着React Native项目的开发,逐渐的Moles框架就形成了。

mole [məʊl] 小鼹鼠,是种凿洞能力非常强的啮齿类动物。把框架称为之为Moles,也是寄希望我们的框架能像mole一样,能够打洞,能够打通Android、iOS、H5、SEO这几个平台。当然一个mole的能力是有限的,所以我们取其复数形式Moles。

如果说当前移动端的三大痛点是:性能、动态性、多端适配的话。那么我认为React Native解决了性能、动态性,而我们Moles则解决了多端适配的问题。

Moles的目标是要尽可能的做到在H5端开发的内容可以直接运行在Native上,在Native端开发的内容也可以直接运行在H5上。

三、Moles 框架的组成

该框架主要由三部分组成:

- moles-web

该部分主要是为H5服务,是将React Native在Android、iOS中没有差异化的Components、APIs提取出来,单独封装成一个Library供H5端来使用。这样做的好处是,这个Library只在H5上会是使用到,在Native是不需要的,以减少框架在Native的体积。

- moles-cui

该部分主要是是将React Native在Android、iOS中有差异化的Components、APIs提取出来,并且添加一些公司定制化的组件进去,包括:UI组件、监控组件、采集组件、路由组件等等。moles-cui可以说是Moles框架的核心部分,它不但Native开发需要使用,在H5上的开发也需要使用。

- moles-cli

该部分主要包括Moles项目的初始化、编译、打包等功能。

四、Moles 框架的功能

Moles框架的功能可以用下图来说明:

主要涵盖的对不同平台的适配、对底层API的调用以及对APP中性能和错误的监控等等。

那么Moles在携程主App中所处的位置如何呢?

如上图所示它就是BU开发人员和React Native、Ctrip React Native 的一个桥梁。让开发人员更专注于自己的业务逻辑,而不必为React Native的更新问题、不同平台的兼容性问题等等而烦恼。

五、Moles 框架的原理简析

由于Moles涉及的内容众多,如:路由的设计、页面生命周期的设计、打包的设计等等。这里我们仅以组件的设计为例,来简析其实现原理。

要做到Native和H5代码共享,通常想到的做法有两种:

1) Native组件运行在H5上,如:

class HelloWorld extends Component{render(){return(<View><Text>HelloWorld</Text></View>)}
}

2)H5组件运行在Native上,如:

class HelloWorld extends Component{render(){return(<Div><Span>HelloWorld</Span></Div>)}
}

Moles中组件的设计采用了做法1的思路,就是将Native上支持的View、Text、Navigator等组件运行在H5上。要实现Native组件运行在H5上,需要解决两个难点:1. 组件化 2. 组件的生命周期。

我们刚开始的时候就讲到,React Native上的组件化思想是Facebook将ReactJS的思想用在Native上。这就为我们能在H5上实现Native的组件奠定了基础。所以我们完全可以借助ReactJS来开发这些组件,但是在实际的开发中,发现ReactJS的体量实在是太大了,所以我们最后采用了携程开源的react-lite框架。

六、Moles 框架的使用

为了减少大家的学习成本,Moles框架在设计方面尽量采用大家比较熟悉的语法和命令。要使用Moles,需要先安装moles-cli。

下面是第一次使用moles-cli的简单流程:

安装moles-cli

$ sudo cnpm install @ctrip/moles-cli -g

初始化Moles项目

$ moles init ProjectName

安装项目依赖

$ cd ProjectName
$ cnpm install

moles-cli初始化后的目录结构和react-native-cli初始化出来的结构几乎一样,唯一不同的是多了一个web目录,该目录主要是为H5服务。

下面来看下简单的代码使用情况

mport React,{View
} from 'react-native'

上面的代码若在Native端会调用React Natie提供的react-native模块,在H5端会调用moles-web模块

import{Application,Page
}from 'moles-cui'

上面的代码为moles-cui的使用,不论在Native端还是H5端,都需要通过引入’moles-cui’模块来使用。

以运行iOS项目为例:

$ moles run-ios

打包、拆包项目

$ moles packer --input /path/to/project
    --entry index.ios.js
    --output /path/to/build
    --bundle bu.bundle
    --common true

参数说明:input:项目目录(默认为当前目录)
entry:入口文件名称(默认为 index.js)
output:输出目录(默认为 ./build 目录)
bundle:默认输出文件名称与入口文件同名,也可指定文件名
common:是否打common包(默认为false)

七、Moles 框架的案例

目前Moles框架已在携程的主App上投入生产,有兴趣的同学可以安装携程App 6.17,进入”我的携程“频道,其中的站内信页面就是基于Moles框架开发的。现在还有攻略、游轮等频道也在陆陆续续的接入中。相信在不久的将来,大家会在携程的各大频道上看到Moles的身影。我们也希望Moles能成为携程乃至业内基于React Native开发项目的首选框架。

下面是基于Moles开发的效果图:

我携频道

攻略频道

八、开源计划

之前分享的时候,就有不少同学咨询开源的事情。这里简述下,Moles未来将是一个开源的框架。是一个为开发React Native项目提供解决方案的开源框架。我们会将Moles框架的相关产品逐步的开源给大家。

目前已将Moles框架的打包工具moles-packer开源在了github上。

关于moles-packer的一些介绍:

moles-packer 是由携程框架团队研发的,与携程Moles框架配套使用的React Native 打包和拆包工具,同时支持原生的 React Native 项目。

当前版本:0.1.3

  • github地址:https://github.com/ctripcorp/moles-packer
  • npm地址:https://www.npmjs.com/package/moles-packer

编辑推荐:架构技术实践系列文章(部分):

  • 魏晓军:React Native实践之携程Moles框架
  • 学霸君姜波:耳目一新的在线答疑服务背后的核心技术
  • 爱乐奇麦凯臻:在线教育的内容研发和技术的迭代创新
  • 长虹李玮:老牌消费电子企业如何拥抱Docker
  • 徐汉彬:日请求过亿的Web系统PHP7升级实践
  • 窦威:AcFun的视频架构演化实践
  • 傅鸿城:QQ亿级日活跃业务后台核心技术揭秘
  • 宁峰峰:尖峰日96万订单,59校园狂欢节技术架构剖析
  • 梁阳鹤:每秒处理10万订单乐视集团支付架构
  • 沈辉煌:亿级日PV的魅族云同步的核心协议与架构实践
  • 李任:携程Docker最佳实践
  • 王海军:游戏研发与运营环境Docker化
  • 史海峰:当当网高可用架构之道
  • 黄哲铿:应对电商大促峰值的九个方法
  • 1号店交易系统架构如何向「高并发高可用」演进
  • 京东闫国旗:从C10K到C10M高性能网络的探索与实践
  • 李林锋:服务化架构的演进与实践
  • 1号店架构师王富平:一号店用户画像系统实践
  • 唯品会官华:实现电商平台从业务到架构的治理体系
  • 沈剑:58同城数据库架构最佳实践
  • 荔枝FM架构师刘耀华:异地多活IDC机房架构
  • UPYUN的云CDN技术架构演进之路
  • 初页CTO丁乐:分布式以后还能敏捷吗?
  • 陈科:河狸家运维系统监控系统的实现方案
  • 途牛谭俊青:多数据中心状态同步&两地三中心的理论
  • 云运维的启示与架构设计
  • 魅族多机房部署方案
  • 艺龙十万级服务器监控系统开发的架构和心得
  • 京东商品详情页应对“双11”大流量的技术实践
  • 架构师于小波:魅族实时消息推送架构

React Native实践之携程Moles框架相关推荐

  1. React Native 实践之携程 Moles 框架

    编者:本文来自携程框架研发部高级经理魏晓军在第二期[携程技术微分享]上的分享,以下为整理后的文字实录.视频回放可点击这里.关注携程技术中心微信公号ctriptech,可获知更多微分享课程信息. 因为支 ...

  2. React Native之携程Moles框架

    http://blog.csdn.net/xiangzhihong8/article/details/51756319 因为支持用JavaScript开发原生应用,React Native一推出就受到 ...

  3. RN开发实践——仿携程App(二)

    文章最后附上源码地址 上一片博客链接RN开发实践--仿携程App(一) 实现首页的轮播图 Swiper简介 The best Swiper component for React Native.Swi ...

  4. RN开发实践——仿携程App(三)

    文章最后附上源码地址 上一片博客链接RN开发实践--仿携程App(二) 实现首页中间的内容栏 今天实现首页中间的内容栏,原效果如下: 红框就是今天需要实现的内容 这里可以拆解成四个部分,每个部分都是由 ...

  5. 全民K歌React Native实践与优化

    PPT主题:全民K歌React Native实践与优化 嘉宾:袁聪1)React Native,H5,Native的优缺点2)React Native优化--Bundle拆分• 业务分离,按需加载,减 ...

  6. 携程React Native实践

    React Native(下文简称 RN)开源已经一年多时间,国内各大互联网公司都在使用,携程也在今年 5 月份投入资源开始引入,并推广给多个业务团队使用,本文将会分享我们遇到的一些问题以及我们的优化 ...

  7. python 携程 apollo_手把手教你使用携程开源框架Apollo(阿波罗)

    配置中心 在现实的Coding工作中,我们是否会遇到这样的问题,我们本地开发环境会用到一套配置参数和配置文件,测试环境会用到另一套配置参数和配置文件,然而项目打包发布时又会用到一套配置参数和配置文件. ...

  8. 【最佳实践】携程服务注册中心架构演进

    1.前言 携程的微服务框架产品从2013年发展至今,已经历了7年多的打造.其中所使用的服务注册中心也从最开始人工数据维护架构演进到了现在全自动.百万容量级的架构.本文将逐一回顾携程服务注册中心所经历的 ...

  9. RN开发实践——仿携程App(一)

    文章最后附上项目地址. 1.新建项目 在控制台执行下面命令( 前提是已经搭建好react-native的开发环境 ): react-native init XieCheng // XieCheng 是 ...

最新文章

  1. how to find your partner
  2. 简介(CAB和SCSF编程)
  3. linux php环境搭建_PHP-小程序:(1)开发环境搭建
  4. 基于JAVA+SpringMVC+Mybatis+MYSQL的校园多媒体大赛设计平台
  5. gawk如何在win7安装_WIN7系统如何安装PS2021?拯救你的WIN7再战斗一年
  6. VisualGDB调试,实现VS环境下调试Android
  7. mysql config type_mysql_config_editor用法举例
  8. 斐讯k3更新mysql_斐讯K3官改,安装onmp教程,回馈社区。-附TCExam后续安装
  9. python whl文件_python whl是什么文件
  10. 移动硬盘打不开怎么办?
  11. word如何给多张图片批量添加边框
  12. win7升级win10正式版_如何使用小白系统对win7升级win10操作
  13. The devil is in the details
  14. STM32F103 读写内部FLASH—学习笔记(野火)
  15. 启动kafka2.8报afka.common.KafkaException: No `meta.properties` found in /tmp/kraft-combined-logs
  16. 【重识云原生】第一章——不谋全局不足以谋一域
  17. Tomcat过时了?别多想,很多公司还是在用的。这份Tomcat架构详解,真的颠覆你的认知
  18. CCF CSP 201803-4 棋局评估
  19. 堪比 007 电影!通过一张照片找到拍照者的精确位置
  20. 聊聊机器人学习中的“投资”与“消费”(节选)

热门文章

  1. 其他:鼠标滚轴坏了如何修?
  2. android 设置textview 左边,Android设置图片在TextView上、下、左、右
  3. 小程序云函数new Date()获取的时间和new Date().getDay()获取的时间不一致 / 云函数存入的时间不对 /小程序云开发配置时区
  4. 玩3D游戏头晕怎么办?为什么会头晕?如何解决?
  5. wgcna 原文复现 小胶质细胞亚群在脑发育时髓鞘形成的作用 microglial
  6. Acme CAD Converter 2019(DWG转换器) v8.9.8.1500简体中文精简优化版
  7. zoc7中文乱码问题解决方法
  8. latex如何换页 一页放不下
  9. (一)Linux中的网络配置
  10. 用Python turtle库 绘制皮卡丘