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 相关文章推荐
Javascript技术技巧大全(五)
Jan 22 Javascript
JavaScript多线程的实现方法
May 08 Javascript
JS启动应用程序的一个简单例子
May 11 Javascript
理解Javascript_06_理解对象的创建过程
Oct 15 Javascript
与Math.pow 相反的函数使用介绍
Aug 04 Javascript
JS 中LocalStorage和SessionStorage的使用
Aug 17 Javascript
node.js基础知识小结
Feb 26 Javascript
Node.js 使用AngularJS的方法示例
May 11 Javascript
详解微信小程序调起键盘性能优化
Jul 24 Javascript
详解CommonJS和ES6模块循环加载处理的区别
Dec 26 Javascript
Node.js API详解之 net模块实例分析
May 18 Javascript
Vue 基于 vuedraggable 实现选中、拖拽、排序效果
May 18 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
Zend 输出产生XML解析错误
2009/03/03 PHP
php网站来路获取代码(针对搜索引擎)
2010/06/08 PHP
php学习之 数组声明
2011/06/09 PHP
PHP+jquery+CSS制作头像登录窗(仿QQ登陆)
2016/10/20 PHP
帮助避免错误的Javascript陷阱清单
2009/05/31 Javascript
jQuery 第二课 操作包装集元素代码
2010/03/14 Javascript
JQuery 动态扩展对象之另类视角
2010/05/25 Javascript
基于jQuery的history历史记录插件
2010/12/11 Javascript
jsvascript图像处理—(计算机视觉应用)图像金字塔
2013/01/15 Javascript
jquery下div 的resize事件示例代码
2014/03/09 Javascript
兼容主流浏览器的jQuery+CSS 实现遮罩层的简单代码
2014/10/14 Javascript
javascript定时器完整实例
2015/02/10 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
jQuery插件pagewalkthrough实现引导页效果
2015/07/05 Javascript
JQuery实现简单的图片滑动切换特效
2015/11/22 Javascript
基于Bootstrap实现tab标签切换效果
2020/04/15 Javascript
JS脚本实现动态给标签控件添加事件的方法
2016/06/02 Javascript
Javascript中return的使用与闭包详解
2017/01/11 Javascript
Vue.js手风琴菜单组件开发实例
2017/05/16 Javascript
js中getter和setter用法实例分析
2018/08/14 Javascript
在vue项目中优雅的使用SVG的方法实例详解
2018/12/03 Javascript
说说如何使用Vuex进行状态管理(小结)
2019/04/14 Javascript
JS实现从对象获取对象中单个键值的方法示例
2019/06/05 Javascript
vue基于v-charts封装双向条形图的实现代码
2019/12/09 Javascript
vue抽出组件并传值实例
2020/07/31 Javascript
python求crc32值的方法
2014/10/05 Python
在Python中使用next()方法操作文件的教程
2015/05/24 Python
python matplotlib画图库学习绘制常用的图
2019/03/19 Python
YOOX美国官方网站:全球著名的多品牌时尚网络概念店
2016/09/11 全球购物
澳大利亚现代波西米亚风格女装网站:Bohemian Traders
2018/04/16 全球购物
香港现代设计家具品牌:Ziinlife Furniture
2018/11/13 全球购物
Michael Kors澳大利亚官网:世界知名的奢侈饰品和成衣设计师
2020/02/13 全球购物
Java语言程序设计测试题改错题部分
2014/07/22 面试题
大学生村官座谈会发言材料
2014/05/25 职场文书
大学生个人简历自荐信
2015/03/06 职场文书
建筑工程催款函
2015/06/24 职场文书