hybrid学习笔记

hybrid是什么

hybrid也就是前端和客户端的混合开发。简单的说就是客户端通过webview组件使用file协议来加载h5页面。
这里提到两个概念,webview和file协议。
webview客户端的一个组件,可用来加载h5页面。
file协议是加载本地文件的协议,它的优势的加载速度快。

为什么使用hybrid

先来说下使用hybrid的优点:

1、可以快速迭代更新,无需应用商店审核
2、体验流畅
3、减少开发和沟通成本,双端共用一套代码。

当然,有优点也有缺点,相对于h5而言,它的缺点有两个:

1、开发成本高,联调,测试和查bug都比较麻烦
2、运营成本高

hybrid的使用场景

1、对产品的体验要求高
2、更新迭代频繁

hybrid是怎么实现的

之前说到hybrid的优点:快速迭代更新和体验流畅,那么hybrid是怎么做到这两点的。也就是以下两个问题:
1、hybrid是怎么更新的?
2、hybrid通过file协议加载h5页面做到体验流畅,那么h5页面是怎么动态获取数据的?

先想下我们更新的目的是什么?

其实就是把APP里面的h5静态页面文件替换掉。

接着再想下有什么好的方式可以做到?

我们的APP已经被安装到客户的手机,APP怎么知道自己要更新呢,这就需要别人来告诉它,这个别人自然就是服务器了。因为APP需要向服务器请求数据,我们可以在APP每次启动时就向服务器发送请求是否需要更新,需要的话就把更新文件下载下来并替换掉旧的文件,这种方式是可行的吧。

那么服务器是怎么知道APP需要更新?

这个可以根据版本号来区分,比如APP当前的版本是1.0,服务器上的是1.2,通过版本的比较就知道是否需要更新了。

版本更新讲完了,接着讲下h5和客户端的通讯

先说下通讯的基本形式

js通过客户端提供的接口,把参数和回调函数传给客户端,客户端执行完后通过回调函数返回数据。
那么它们是如何通讯的,这里就要讲到一个新的协议--schema协议

schema协议是什么?

schema协议是用来规定前端和客户端如何通讯的协议。这样说好像跟没说一样,那么我们就说下schema协议是怎么使用的

var iframe = document.createElement('iframe');
iframe.style.display = 'none';
iframe.src = 'weixin://dl/scan?k1=v1&k2=v2&k3=v3&callback=_invoke_scan_callback_'      //把iframe的src属性设置为客户端定义的接口
var body = document.body;        
body.appendChild(iframe);        //执行到这一步就会调用客户端的接口
setTimeout(function(){
  body.removeChild(iframe);      //执行完后要清除
  iframe = null
},0)

是不是很简单,但是每次这么调用也太麻烦了,所以最好是封装成一个接口,方便调用。

//invoke.js
(function (window, undefined) {

    // 调用 schema 的封装
    function _invoke(action, data, callback) {
        // 拼装 schema 协议
        var schema = 'myapp://utils/' + action

        // 拼接参数
        schema += '?a=a'
        var key
        for (key in data) {
            if (data.hasOwnProperty(key)) {
                schema += '&' + key + data[key]
            }
        }

        // 处理 callback
        var callbackName = ''
        if (typeof callback === 'string') {
            callbackName = callback
        } else {
            callbackName = action + Date.now()
            window[callbackName] = callback
        }
        schema += 'callback=callbackName'

        // 触发
        var iframe = document.createElement('iframe')
        iframe.style.display = 'none'
        iframe.src = schema  // 重要!
        var body = document.body
        body.appendChild(iframe)
        setTimeout(function () {
            body.removeChild(iframe)
            iframe = null
        })
    }

    // 暴露到全局变量
    window.invoke = {
        share: function (data, callback) {
            _invoke('share', data, callback)
        },
        scan: function (data, callback) {
            _invoke('scan', data, callback)
        }
        login: function (data, callback) {
            _invoke('login', data, callback)
        }
    }

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,504评论 25 707
  • ①昨天晚上回到家之后,吃饭的时候我就说,哎呀,这么冷的天,一回到家就这么暖和,而且还有这么好吃的菜,我真是太幸福了...
    彩茹宝贝阅读 191评论 0 0
  • 她负了父母,负了族人,只为助他登上皇位。 她有倾世之妖颜,古潭般深的心计,五年时间,他即将登基。 那日,他揽她入怀...
    Su1_染阅读 167评论 1 0
  • 赶在11月最后一天的最后半小时,对11月做了总结,对12月做了业余学习计划,并制作了打卡表,希望2017年的最后一...
    雅俗儿的手帐阅读 1,550评论 9 19