从Hybrid到React-Native: JS在移动端的南征北战史
注:因为不了解Dart,所以本文不对flutter相关内容进行阐述, 实在抱歉
其实写这篇文章的时候,我就知道,肯定有人问我:为什么不写flutter?抱歉了,flutter的大名我当然知道,可我只是一个写JS的,同时了解一些Java的知识,而flutter采用的编程语言,我暂时没有碰过,所以自然不敢妄加猜度,还请谅解
Hybrid
Hybird的实现方式
- 原生端怎么调用JS代码
- JS代码怎么调用原生端
- Q1: JS怎么调用Android代码
- Q2: Android代码怎么调用JS
- Q3: JS怎么调用IOS代码
- Q4: IOS代码怎么调用JS
Q1: JS怎么调用Android代码
- JSInterface
- JSBridge
- UrlRouter
webView.addJavascriptInterface(new JsInterface(), "control”);
// …
public class JsInterface {
@JavascriptInterface
public void showToast(String toast) {
Toast.makeText(MainActivity.this, toast, Toast.LENGTH_SHORT).show();
log("show toast success");
} }
// WebView中的JS代码,注意control就是上面addJavascriptInterface定义的命名空间
function showToast(toast) {
javascript:control.showToast(toast);
}
Q2: Android怎么调JS代码?
webView.loadUrl(“...//my.html”);
webView.evaluateJavascript(“JS代码”,Callback对象)
Q3: IOS代码怎么调用JS
Q4: JS怎么调用IOS代码
React-Native
RN的作用
- 跨平台:可以为IOS/Android,甚至Windows Phone开发原生应用
- 相对良好的UI体验,平衡开发成本和用户体验后相对合理的选择
RN的本质
- 不是WebView,和Cordova等Hybrid方案划清界限
- 不将JavaScript预编译为Native代码,和Xamarin等方案划清界限。Xammarin的方案是AOT的,运行前就编译为原生代码,RN则采用JIT+解释器的方案(IOS另当别论)
- RN是虚拟机类的方案,依靠运行时系统JavaScriptCore运行
RN的4个线程
- UI线程:也成为主线程,负责本机的Android/iOS的UI呈现,在android中它负责android测量/布局/绘制
- JS线程:执行JS/React代码,进行API调用,处理触摸事件等,对视图的更新被进行批处理,并在事件循环结束时发送给UI线程
- Shadow线程:处理虚拟DOM布局变更的线程
- 本机模块线程: 如android/ios系统自带的原生API
RN的3部分
- Native端(IOS/android)
- JavaScript端
- Bridge:上面介绍的多个线程之间相互通信,以及JS和Native端通信的方式的统称
线程协调过程示例
<View style={{ flex: 1, justifyContent: "center", alignItems: "center" }}>
  <View style={{width: 100, height: 100, backgroundColor: "red"}}></View>
</View>
- 注意原生端有自己的布局实现,所以上面的flex属性和CSS是没有任何关系的。
- 为了实现布局,同时又不阻塞JS线程,布局计算将转移到Shadow线程中进行。
- Shadow线程进行计算,并最终将计算结果得到的布局参数传递给主线程(UI线程),实现UI的构建
RN中的Bridge做了什么? && RN线程如何交互?
- 异步:线程之间,例如JS线程和UI线程,以异步的方式进行通信,这样它们就不会互相阻塞了
- 批处理: 以优化的方式, 把消息从一个线程传递到另外一个线程
- 序列化: 两个线程不会操作或者共享同一块数据,它们之间会通过序列化和反序列化的方式交换消息
RN线程异步带来的某些问题 && 未来的解决方案
RN的Web化:react-native-web
RN-web和普通的React的区别?
RN-WEB的作用
参考文章
从Hybrid到React-Native: JS在移动端的南征北战史的更多相关文章
- 什么是 Native、Web App、Hybrid、React Native 和 Weex?(转载)
		什么是 Native.Web App.Hybrid.React Native 和 Weex? 来源:zwwill_木羽 segmentfault.com/a/1190000011154120 一句 ... 
- Hybrid APP基础篇(二)->Native、Hybrid、React Native、Web App方案的分析比较
		说明 Native.Hybrid.React.Web App方案的分析比较 目录 前言 参考来源 前置技术要求 楔子 几种APP开发模式 概述 Native App Web App Hybrid Ap ... 
- Native、Web App、Hybrid、React Native(简称RN)、Weex 间的异同点。
		App常用开发模式简介 此处App为应用application,并非我们通常讲的手机App. 常用的几种APP开发模式-脑图 Native App 传统的原生App开发模式,有iOS和aOS两大系统, ... 
- 【REACT NATIVE 系列教程之十二】REACT NATIVE(JS/ES)与IOS(OBJECT-C)交互通信
		http://blog.csdn.net/xiaominghimi/article/details/51586492 一用到跨平台的引擎必然要有引擎与各平台原生进行交互通信的需要.那么Himi先讲解R ... 
- 基于React Native的跨三端应用架构实践
		作者|陈子涵 编辑|覃云 “一次编写, 到处运行”(Write once, run anywhere ) 是很多前端团队孜孜以求的目标.实现这个目标,不但能以最快的速度,将应用推广到各个渠道,而且还能 ... 
- Hybrid App 和 React Native 开发那点事
		简介:Hybrid App(混合模式移动应用)开发是指介于Web-app.Native-App这两者之间的一种开发模式,兼具「Native App 良好用户交互体验的优势」和「Web App 跨平台开 ... 
- ReactJs和React Native的那些事
		介绍 1,React Js的目的 是为了使前端的V层更具组件化,能更好的复用,它能够使用简单的html标签创建更多的自定义组件标签,内部绑定事件,同时可以让你从操作dom中解脱出来,只需要操作数据就会 ... 
- ReactJs和React Native的联系和差异
		1,React Js的目的 是为了使前端的V层更具组件化,能更好的复用,它能够使用简单的html标签创建更多的自定义组件标签,内部绑定事件,同时可以让你从操作dom中解脱出来,只需要操作数据就会改变相 ... 
- React Native入门指南
		转载自:http://www.jianshu.com/p/b88944250b25 前言 React Native 诞生于 2015 年,名副其实的富二代,主要使命是为父出征,与 Apple 和 Go ... 
随机推荐
- Java笔记(持续更新中)
			Java语言的特点: 面向对象(封装,继承,多态) 平台无关性(JVM运行.class文件) 语言(泛型,Lambda) 类库(集合,并发,网络,IO/NIO) JRE(Java运行环境,JVM,类 ... 
- Python循环语句及函数的定义
			循环语句¶ 重复执行某一个固定的动作或者任务 语法 for 变量 in序列: 语句1 语句2 ..... In [2]: # 列表知识只是以后会讲 # 比如[1,2,3,4,5,6,7] list ... 
- 16.XML语法、CDATA、约束(DTD、Schema)讲解
			xml主要用来描述数据,比如配置文件,网络之间传输数据等,并且在android中也经常用xml来布局,,接下来便来学习xml常用的东西 1.XML语法 xml语法分为: 1.1 文档声明 必须位于文档 ... 
- ECMAScript---object对象类型详解
			普通对象:由大括号包裹起来的,由零到多个属性名和属性值(键值对)组成的 那什么是属性呢? 属性:描述当前对象特征的,属性名是当前具备这个特征,属性值是这个特征的描述(专业语法,属性名称为键[key], ... 
- 简单易懂的banner图滚动源代码
			banner图左右滚动简单易懂源代码 1 样式展示 css代码: * { padding: 0px; margin: 0px; } .banner { width: 100%; height: 450 ... 
- 常用Linux备份
			用于备份的Tar 备份工具Tar是以前备份文件的可靠方法,几乎可以工作于任何环境中,Linux老用户一般都信赖它. Linux中以.tar结尾的文件都是用tar创建的.它的使用超出了单纯的备份,可用来 ... 
- Linux--进程管理--06
			1.操作系统的基础 调用:kernel通过给应用程序提供system call的方式来提供硬件资源: 注意:应用程序也包括库文件 库文件是运行在ring0上的一段程序代码,不对客户直接提供应用 2.程 ... 
- 最简单流处理引擎——Kafka Streaming简介
			Kafka在0.10.0.0版本以前的定位是分布式,分区化的,带备份机制的日志提交服务.而kafka在这之前也没有提供数据处理的顾服务.大家的流处理计算主要是还是依赖于Storm,Spark Stre ... 
- Api接口文档管理工具,你知道哪些呢?
			上周看到有人在我的Github开源项目中提了个issue,说是否考虑接入swagger.那今天我就用swagger与其他接口文档工具做对比,同时说说Api接口文档工具的那点事.如今,在前后端分离开发的 ... 
- ccpc网赛 hdu6705 path(队列模拟 贪心
			http://acm.hdu.edu.cn/showproblem.php?pid=6705 这是比赛前8题过的人数第二少的题,于是就来补了,但感觉并不难啊..(怕不是签到难度 题意:给个图,给几条路 ... 
