cordova和react-native 底层的实现思路的区别

cordova当中主要有3者协同工作,一个native runtime,一个js bridge,一个web view。
js bridge为web view封装了一堆native api供调用。
当你只想跑一个普普通通的网页的时候,web view提供的那些浏览器js api就够用了,你调用它们,就只和web view打交道。
而如果你要调用cordova给你封装的那一堆扩展的api,这些调用就最终落实到native runtime上面来实现。

react native中主要也有3者协同工作,一个native runtime,一个js bridge,一个js runtime。
这个js runtime不是web view,你可以理解为它就是个类似于nodejs这类的东西吧,所以它自然也不会有浏览器里那些window/document这类的api。
当你在js runtime里调用native api,比如生产了一个Button,js bridge会把这件事告诉native runtime,native runtime就生成了一个native的Button。
由于两个runtime之间无法直接交换数据,所以js bridge一般会用id mapping方式来实现对象式的试图操作(当然react native是不是这么做的我不太清楚)。
比如,native runtime那边给native Button分配一个id,js bridge就给js runtime这边分配一个具有相同id的“傀儡”Button,这两者就通过这个id关联起来了。
你调用button.show()的时候,js bridge事实上是传递一个,打个比方,{ id: 10, method: 'show', arguments: [] }的消息给native runtime,后者照做就行。
这样做的结果是,你在js runtime里做的任何接口调用,都通过js bridge,落实到native runtime上来实现。

说简单点
cordova对浏览器做了一大堆扩展api,你的程序是一个网页。
react native是在native app里引入了一个脚本语言,只是,这个脚本语言刚好是js,它也可以是lua也可以是别的,你写的程序是js在“遥控”一个native app。

原文出处:https://www.zhihu.com/question/47053259/answer/132975841
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值