美文网首页
hybrid学习笔记

hybrid学习笔记

作者: lzb30 | 来源:发表于2018-04-11 00:59 被阅读0次

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就能跟客户端通讯了。

相关文章

  • hybrid学习笔记

    hybrid是什么 hybrid也就是前端和客户端的混合开发。简单的说就是客户端通过webview组件使用file...

  • 学习笔记-Hybrid App

    1. webview控件在appium的抽象 1.1 Native层面支持 uiautomator解析webvi...

  • hybrid学习

    本文旨在介绍几种hybrid解决方案的渲染区别, 对hybrid学习做粗略学习,便于以后技术选型时能清楚各自的优劣...

  • Hybrid案例学习

    tags: ["Hybrid"]categories: ["iOS"] 花了两三天时间试用了一下Cordova,也...

  • HybridApp

    iOS Hybrid 框架 - PhoneGap iOS Hybrid 框架Hybrid App 开发(开篇) ...

  • Hybrid APP - 混合式开发

    Hybrid APP基础篇(一)->什么是Hybrid App Hybrid APP基础篇(二)->Native、...

  • 2019-8-25 每日一词

    Hybrid His work is an interesting hybrid of popular and c...

  • hybrid的机制学习

    对于hybrid真正的接触和深入了解,是从来到这家公司开始的,之前虽然接触过,但是那个时候使用的都是各种sdk,面...

  • 微信小程序总结(一)

    前言 由于Hybrid开发的APP已经顺利上线,然后就去学习了下微信小程序。顺便一提有对Hybrid感兴趣的小朋友...

  • 移动应用框架分析

    前言 Hybrid App:PhoneGap、Titanium、WeX5、AppCan... 优于Hybrid A...

网友评论

      本文标题:hybrid学习笔记

      本文链接:https://www.haomeiwen.com/subject/pomohftx.html