vue与原生app的对接交互的方法(混合开发)
小伙伴们在用vue开发h5项目特别是移动端的项目,很多都是打包后挂载在原生APP上的,那就少不了与原生交互了,我最近就是在坐这个,踩了一些坑,拿出来给大家分享下。
0.通过url传输数据(一般是在入口页面传下app的用户信息进来供vue h5使用)
methods: { // 接收url后的数据 urltext() { let loc = location.href; 6 let n1 = loc.length;//地址的总长度 let n2 = loc.indexOf("=");//取得=号的位置 let outToken = loc.substr(n2 + 1, n1 - n2);//从=号后面的内容 console.log(loc,n1,n2,outToken) this.outTokenPost(outToken) //传到处理函数 }, }
1.原生APP提供一个接口对象的引用(例如一个扫码的接口,可能还有回调函数以获得扫码结果)
思路就是万物通过window 进行交互
// 将vue组件的要回调的函数暴露出去 mounted:function(){ // 将subscanQRCallBack方法绑定到window狼蚁网站SEO优化,提供给外部调用 window['scanQRCallBack'] = (result) => { this.subscanQRCallBack(result) } }, methods:{ scan(){ // alert('开始扫码了') window.client.startScanQR('OS与js交互',scanQRCallBack) // 通过window调用app提供的client对象 }, subscanQRCallBack(result){ // alert('扫码结果6466'+result); this.scanPost(result) }, }
由交互引发的对vue生命周期的思考
开发时遇到一个经典问题,需要在页面刚载入时与app交互判断是否显示一个弹窗。看似很简单,进入页面调一个交互方法即可,但这个需求的解决经历了几个步骤
1、created
因为created时,实例就创建完成了,我开始的选择是在此生命周期挂载方法并调用交互,结果页面闪退,猜测实例虽有,但模板未编译挂载,app调用方法失败导致闪退
2、mounted
第二次将挂载和调用写在了mounted内,结果页面闪退,猜测(误)挂载和调用靠的太近,可能方法未挂载完就直接调用,导致闪退
3、created+mounted
created内挂载方法,mounted内调用交互,结果我的ios12无异常,几乎以为成功时,ios10还是发生了闪退,猜测ios12的webview对此问题进行了优化,考虑兼容性,方案不可行。
4、延时
猜测是window没有加载完便调用了window下的方法,导致闪退,对交互方法加了1s延时,成功!但体验一般,因为硬性的定时容易引发许多不可控的问题,而且弹窗延时的存在导致用户体验低下。
5、window.onload
onload 事件会在页面或图像加载完成后立即发生。mounted钩子里添加代码window.onload=function(){//调用交互},在window加载完成以后触发交互,而且此时间节点在vue的生命周期是不存在的,也是在mounted、created钩子后发生的,这个原生的方法还是很棒的,完美解决~!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程