hybrid 开发

概念

hybrid: 就是前端和客户端的混合开发, 让App同时具备原生和Web 的技术优势。【需要前端开发人员和客户端开发人员配合完成】

特点

1、可以快速迭代更新【关键】,无需APP审核(hybrid技术可以一天上线多次)
2、体验流畅(和Native开发的体验基本类似)
3、减少开发和沟通成本,双端公用一套代码
4、相对于纯原生开发, 缺点: 性能问题, 兼容性问题 【Android 5.0+ 和 IOS 9.0+上缺点不再明显】

理解webview

是APP中的一个组件(App可以有Webview,也可以没有), 主要用于加载H5页面,是一个小型的浏览器内核。

hybrid应用场景

1、微信公众号, 通过JSSDK连接Native 和 web端
2、微信小程序,通过内置框架连接Native 和 web端


hybrid.png
hybrid核心技术 --- JSBridge桥接器

1、实现Native端和web端双向通信的一种机制
2、以Javascript引擎或Webview容器为媒介
3、通过约定协议进行通信

hybrid主流技术框架

1、Web渲染: Cordova 【前身是PhoneGap】
2、原生渲染: React Native、Weex
3、混合渲染: 微信小程序

JSBridge 实现原理
4.png

1、类比Client/Server
2、将Native端原生接口封装成Javascript接口
3、将Web端原生接口封装成Native端原生接口
4、Web端和Native端之间双向通信

JSBridge两种实现方式 【指web调用原生端, 原生端调用web端只有执行js代码一种方式】

一、拦截WebView请求的URL Schema

1、URL Schema : 是URL的一种请求格式 【<prototal>://<domain>/<path>?<query>】
2、自定义JSBridge通信的URL Schema 【jsbridge://<method>?<params> ------ 如:jsbridge://showToast?text=hello

5.png

如图: 两条线, 1、如果符合我们的 URL Schema, 就会拦截解析url 调用原生的方法, 2、如果是正常的url,则走正常的服务端请求。
优点:兼容性好
缺点: 不直观、url长度有限制

// 实践
// 1 natvie 调用web方法 【如 调用web弹窗】
// 原生端调用web端只有执行js代码一种方式
private void showWebDialog(string text) {
      String jsCode = String.format("window.showWebDialog('%s')",  text)
      webView.evaluateJavascript(jsCode, null) // webView 引擎去执行
} // 然后再去 web端实现showWebDialog方法
// web端调用native端
// web
showBtn.addEventListener(‘click’, e => {
    const inputValue = editText.value
    showNativeDialog(inputValue)
})
function showNativeDialog(text) {
    window.alert('jsbridge://showNativeDialog?text=' + text) // native拦截
}
// native
...
// 拦截里面...
if ( !message.startWith('jsbridge://') ) {
   return ... // 走默认的
} else {
  showNativeDialog(text)
}
private void showNativeDialog(text) {
    ...
}

二、向WebView注入JS API

App 向webView注入一个js对象提供给webView用, 方法名、参数和app方法一致


1.png

优点: 简单直观
缺点: 有兼容性问题 (Android 4,2+)

// 1、native调用web不变 都是通过执行js脚本
// web端掉用native端
// web
showBtn.addEventListener(‘click’, e => {
    const inputValue = editText.value
    showNativeDialog(inputValue)
})
function showNativeDialog(text) {
    // window.alert('jsbridge://showNativeDialog?text=' + text) // native拦截
  window.NativeBridge.showNativeDialog(text)
}
// native
webView.addJavascriptInterface(new NativeBridge(this),  'NativeBridg') // addJavascriptInterface 原生端向wevView注入对象的方法
class   {
    private ctx
    NativeBridge(ctx) {
        this.ctx = ctx
   }
  @addJavascriptInterface
  private void showNativeDialog(text) {
      ...
  }
}

* 以上其实都是单向的、不能把调用后返回的结果传回, 下面将介绍带回调的JSBridge

1、在对端执行操作并返回结果
2、有输入有输出才是完整的调用


2.png

eg: 在web端获取app端某个输入框的值,并用web弹框展示。

let id = 1
const callbackMap = {}
window.JSSDK = {
    getNativeEditTextValue ( callback) {
        // 
      const callbackId = id ++ 
      callbackMap[callbackId] = callback
      NativeBridge.getNativeEditTextValue(callbackId)
    },
    receiveMessge(callbackId, value) { // 接收
      if (callbackMap[callbackId]) {
        callbackMap[callbackId](value)
      }
   }
}
showBtn2.addEventListener(‘click’, e => {
    JSSDK.getNativeEditTextValue(value => window.alert(`native 输入值:${value}`))
})
// native
class   {
    private ctx
    NativeBridge(ctx) {
        this.ctx = ctx
   }
  @addJavascriptInterface
   private void getNativeEditTextValue(callbackId) {
       ...
      // receiveMessge
   }
}

JSBridge的开源实现

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

推荐阅读更多精彩内容