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


Posted in Javascript onNovember 28, 2018

小伙伴们在用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下面,提供给外部调用
        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钩子后发生的,这个原生的方法还是很棒的,完美解决~!

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

Javascript 相关文章推荐
jquery CSS选择器笔记
Mar 29 Javascript
jquery获取iframe中的dom对象(两种方法)
Jul 02 Javascript
js将json格式内容转换成对象的方法
Nov 01 Javascript
js防阻塞加载的实现方法
Sep 09 Javascript
JavaScript制作颜色反转小游戏
Sep 25 Javascript
jQuery插件autocomplete使用详解
Feb 04 Javascript
Node.js利用断言模块assert进行单元测试的方法
Sep 28 Javascript
js数组常用最重要的方法
Feb 04 Javascript
微信小程序排坑指南详解
May 23 Javascript
基于Fixed定位的框选功能的实现代码
May 13 Javascript
js实现盒子拖拽动画效果
Aug 09 Javascript
JavaScript实现滑块验证解锁
Jan 07 Javascript
vue微信分享出来的链接点开是首页问题的解决方法
Nov 28 #Javascript
vue实现微信分享功能
Nov 28 #Javascript
vue微信分享到朋友圈 vue微信发送给好友
Nov 28 #Javascript
详解小程序rich-text对富文本支持方案
Nov 28 #Javascript
微信小程序实现简单评论功能
Nov 28 #Javascript
微信小程序实现省市区三级地址选择
Jun 21 #Javascript
Vue一次性简洁明了引入所有公共组件的方法
Nov 28 #Javascript
You might like
php 图片加水印与上传图片加水印php类
2010/05/12 PHP
PHP父类调用子类方法的代码例子
2014/04/09 PHP
php实现过滤字符串中的中文和数字实例
2015/07/29 PHP
PHP多进程简单实例小结
2019/11/09 PHP
PHP读取文件或采集时解决中文乱码
2021/03/09 PHP
TNC vs IO BO3 第二场2.13
2021/03/10 DOTA
文字幻灯片
2006/06/26 Javascript
JavaScript与C# Windows应用程序交互方法
2007/06/29 Javascript
js右键菜单效果代码
2007/07/21 Javascript
javascript 带有滚动条的表格,标题固定,带排序功能.
2009/11/13 Javascript
深入理解javascript学习笔记(一) 编写高质量代码
2012/08/09 Javascript
javascript实现的平方米、亩、公顷单位换算小程序
2014/08/11 Javascript
javascript数组输出的两种方式
2015/01/13 Javascript
JS实现简单的图书馆享元模式实例
2015/06/30 Javascript
js流动式效果显示当前系统时间
2016/05/16 Javascript
jQuery EasyUI框架中的Datagrid数据表格组件结构详解
2016/06/09 Javascript
Javascript中的迭代、归并方法详解
2016/06/14 Javascript
jQuery中Chosen三级联动功能实例代码
2017/03/07 Javascript
对vue里函数的调用顺序介绍
2018/03/17 Javascript
jQuery实现判断滚动条滚动到document底部的方法分析
2019/08/27 jQuery
layui use 定义js外部引用函数的方法
2019/09/26 Javascript
Vue项目中使用jsonp抓取跨域数据的方法
2019/11/10 Javascript
手写Vue2.0 数据劫持的示例
2021/03/04 Vue.js
[00:09]DOTA2全国高校联赛 精彩活动引爆全场
2018/05/30 DOTA
python使用sorted函数对列表进行排序的方法
2015/04/04 Python
python networkx 包绘制复杂网络关系图的实现
2019/07/10 Python
django 中QuerySet特性功能详解
2019/07/25 Python
Python原始套接字编程实例解析
2020/01/29 Python
python中spy++的使用超详细教程
2021/01/29 Python
Lampegiganten丹麦:欧洲领先的照明网上商店
2018/04/25 全球购物
无财产无子女离婚协议书范文
2014/09/14 职场文书
国庆节促销广告语2014
2014/09/19 职场文书
施工安全保证书
2015/05/09 职场文书
2016年秋季运动会加油稿
2015/12/21 职场文书
安全学习心得体会范文
2016/01/18 职场文书
《曾国藩家书》读后感——读家书,立家风
2019/08/21 职场文书