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 相关文章推荐
网易JS面试题与Javascript词法作用域说明
Nov 09 Javascript
基于jquery异步传输json数据格式实例代码
Nov 23 Javascript
基于JavaScript将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
Dec 28 Javascript
vue2笔记 — vue-router路由懒加载的实现
Mar 03 Javascript
解决JS外部文件中文注释出现乱码问题
Jul 09 Javascript
vuex中使用对象展开运算符的示例
Sep 25 Javascript
原生js实现淘宝放大镜效果
Oct 28 Javascript
JavaScript实现五子棋游戏的方法详解
Jul 08 Javascript
对layui中的onevent 和event的使用详解
Sep 06 Javascript
vue 使用vant插件做tabs切换和无限加载功能的实现
Nov 04 Javascript
js前端传json后台接收‘‘被转为quot的问题解决
Nov 12 Javascript
使用Canvas绘制一个游戏人物属性图
Mar 25 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
推荐Discuz!5的PHP代码高亮显示与实现可运行代码
2007/03/15 PHP
php获取本周星期一具体日期的方法
2015/04/20 PHP
PC端微信扫码支付成功之后自动跳转php版代码
2017/07/07 PHP
js 验证密码强弱的小例子
2013/03/21 Javascript
详细介绍8款超实用JavaScript框架
2013/10/25 Javascript
关于Javascript作用域链的八点总结
2013/12/06 Javascript
angularJS之$http:与服务器交互示例
2017/03/17 Javascript
Vue中父组件向子组件通信的方法
2017/07/11 Javascript
vue实现图片加载完成前的loading组件方法
2018/02/05 Javascript
vue 实现边输入边搜索功能的实例讲解
2018/09/16 Javascript
微信小程序页面调用自定义组件内的事件详解
2019/09/12 Javascript
对layui中table组件工具栏的使用详解
2019/09/19 Javascript
微信小程序实现打开并下载服务器上面的pdf文件到手机
2019/09/20 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
2020/04/23 Javascript
使用Vant完成通知栏Notify的提示操作
2020/11/11 Javascript
python ip正则式
2009/05/07 Python
Python实现扫描局域网活动ip(扫描在线电脑)
2015/04/28 Python
python实现web方式logview的方法
2015/08/10 Python
神经网络python源码分享
2017/12/15 Python
解决Pycharm后台indexing导致不能run的问题
2019/06/27 Python
Python属性和内建属性实例解析
2020/01/14 Python
Python计算IV值的示例讲解
2020/02/28 Python
Python关键字及可变参数*args,**kw原理解析
2020/04/04 Python
python自动提取文本中的时间(包含中文日期)
2020/08/31 Python
python工具——Mimesis的简单使用教程
2021/01/16 Python
细说CSS3中box属性中的overflow-x属性和overflow-y属性值的效果
2014/07/21 HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
2021/02/03 HTML / CSS
ALDO英国官网:加拿大女鞋品牌
2018/02/19 全球购物
日本最大化妆品和美容产品的综合口碑网站:cosme shopping
2019/08/28 全球购物
销售主管竞聘书
2014/03/31 职场文书
抽奖活动主持词
2014/03/31 职场文书
商务经理岗位职责
2014/07/30 职场文书
认真学习保证书
2015/02/26 职场文书
自主招生专家推荐信
2015/03/26 职场文书
四年级作文之说明文作文
2019/10/14 职场文书
Redis如何实现分布式锁
2021/08/23 Redis