vue与原生应用的对接交互的方法(混合开发)

  

小伙伴们在用vue开发编辑项目特别是移动端的项目,很多都是打包后挂载在原生应用上的,那就少不了与原生交互了,我最近就是在坐这个,踩了一些坑,拿出来给大家分享下。

  

0。通过url传输数据:(一般是在入口页面传下应用程序的用户信息进来供vue代替使用)

        方法:{//接收url后的数据   urltext () {   让loc=location.href;6让n1=loc.length;//地址的总长度   让n2=loc.indexOf("=");//取得=号的位置   让outToken=loc。substr (n2 + 1, n1 - n2);//从=号后面的内容   console.log (loc, n1、n2 outToken)   this.outTokenPost (outToken)//传到处理函数   },   }   之前      

1。原生应用提供一个接口对象的引用(例如一个扫码的接口,可能还有回调函数以获得扫码结果)

  

思路就是万物通过窗口进行交互

     //将vue组件的要回调的函数暴露出去   安装:函数(){//将subscanQRCallBack方法绑定到窗下面,提供给外部调用   窗口[' scanQRCallBack ']=(结果)=比;{   this.subscanQRCallBack(结果)   }      },      方法:{   扫描(){//警报(“开始扫码了”)   window.client.startScanQR(“操作系统与js交互’,scanQRCallBack)//通过窗口调用应用提供的客户对象   },      subscanQRCallBack(结果){//警报(“扫码结果6466:”+结果);   this.scanPost(结果)   },   }      之前      

<强>由交互引发的对vue生命周期的思考
  

  

开发时遇到一个经典问题,需要在页面刚载入时与应用交互判断是否显示一个弹窗,看似很简单,进入页面调一个交互方法即可,但这个需求的解决经历了几个步骤:

  

<强> 1,创建
  

  

因为创建时,实例就创建完成了,我开始的选择是在此生命周期挂载方法并调用交互,结果:页面闪退,猜测:实例虽有,但模板未编译挂载,应用调用方法失败导致闪退

  

<强> 2,安装
  

  

第二次将挂载和调用写在了安装内,结果:页面闪退,猜测(误):挂载和调用靠的太近,可能方法未挂载完就直接调用,导致闪退

  

<强> 3,创建+安装
  

  

内创建挂载方法,安装内调用交互,结果:我的ios12无异常,几乎以为成功时,ios10还是发生了闪退,猜测ios12的webview对此问题进行了优化,考虑兼容性,方案不可行。

  

<强> 4,延时
  

  

猜测是窗户没有加载完便调用了窗口下的方法,导致闪退,对交互方法加了1 s延时,成功!但体验一般,因为硬性的定时容易引发许多不可控的问题,而且弹窗延时的存在导致用户体验低下。

  

<强> 5,窗口。onload
  

  

onload事件会在页面或图像加载完成后立即发生.mounted钩子里添加代码window=function(){//调用交互},在窗口加载完成以后触发交互,而且此时间节点在vue的生命周期是不存在的,也是在安装,创建钩子后发生的,这个原生的方法还是很棒的,完美解决~ !
  

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

vue与原生应用的对接交互的方法(混合开发)