美文网首页移动端混合开发系列
vue与原生混合开发如何与原生安卓,IOS交互

vue与原生混合开发如何与原生安卓,IOS交互

作者: 杨先生o丶 | 来源:发表于2019-03-27 10:26 被阅读2次

    前言介绍

    使用 WebViewJavascriptBridge当 H5 页面与 IOS 端交互比较复杂时,比如页面需要获取 IOS 端传回的返回值,或者 IOS 端需要调用 js 方法。可以通过第三方库来实现,   我们项目用的是 WebViewJavascriptBridge

    1.创建 src/config/bridge.js 文件,用于封装 WebViewJavascriptBridge

    2.将以下代码拷贝到 bridge.js 文件中

    function setupWebViewJavascriptBridge(callback) {

        if (window.WebViewJavascriptBridge) {

          return callback(window.WebViewJavascriptBridge)

        }

        if (window.WVJBCallbacks) {

          return window.WVJBCallbacks.push(callback)

        }

        window.WVJBCallbacks = [callback]

        let WVJBIframe = document.createElement('iframe');

        WVJBIframe.style.display = 'none'

        WVJBIframe.src = 'https://__bridge_loaded__'

        document.documentElement.appendChild(WVJBIframe);

        setTimeout(() => {

          document.documentElement.removeChild(WVJBIframe)

        }, 0)

      }

      export default {

        callhandler(name, data, callback) {

          setupWebViewJavascriptBridge(function (bridge) {

            bridge.callHandler(name, data, callback)

          })

        },

        registerhandler(name, callback) {

          setupWebViewJavascriptBridge(function (bridge) {

            bridge.registerHandler(name, function (data, responseCallback) {

              callback(data, responseCallback)

            })

          })

        }

      }

    3.在 main.js 中引入该文件

    import Bridge from './config/bridge.js'

      Vue.prototype.$bridge = Bridge

    4.然后调取你想要的方法,也就是安卓或则IOS给你写的方法(事先需要与客户端同事约定好方法名)

    this.$bridge.callhandler('方法名', params, (data) => { // 处理返回数据 })

    以下为我的代码

    5.这样就可以调到安卓或则IOS给你写的方法了 

    6.安卓或IOS调你的JS方法

    this.$bridge.registerhandler('JS Echo', (data, responseCallback) => { alert('JS Echo called with:', data) responseCallback(data) })

    7.打包 最关键的一步  ,因为你现在运用了iOS和安卓给你提供的方法 ,所以打包时 ,也需要把他们 的代码集成在一起打包进去,这时  用简单的Hbuilder打包肯定不行了,就需要用android studio打包了 把vue nom ru build出来的dist目录中的index.html放这里

    同时注意这里也要改动

    这布具体问安卓开发,因为我不是专业安卓开发

    写的不是很详细,另有不懂的请私信我,QQ:362960082   验证问题随便输入

    相关文章

      网友评论

        本文标题:vue与原生混合开发如何与原生安卓,IOS交互

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