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 使FORM表单的所有元素不可编辑的示例代码
Oct 17 Javascript
jquery单行文字向上滚动效果的实现代码
Sep 05 Javascript
javascript使用输出语句实现网页特效代码
Aug 06 Javascript
jQuery EasyUI Dialog拖不下来如何解决
Sep 28 Javascript
三个js循环的关键字示例(for与while)
Feb 16 Javascript
javascript html5 canvas实现可拖动省份的中国地图
Mar 11 Javascript
vue mint-ui学习笔记之picker的使用
Oct 11 Javascript
JavaScript算法学习之冒泡排序和选择排序
Nov 02 Javascript
微信小程序 下拉刷新及上拉加载原理解析
Nov 06 Javascript
微信小程序实现上拉加载功能
Nov 20 Javascript
vue项目实现多语言切换的思路
Sep 17 Javascript
如何使用RoughViz可视化Vue.js中的草绘图表
Jan 30 Vue.js
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 批量删除 sql语句
2009/06/05 PHP
js 延迟加载 改变JS的位置加快网页加载速度
2012/12/11 Javascript
用JavaScript修改CSS属性的代码
2013/05/06 Javascript
基于jquery实现的可编辑下拉框实现代码
2014/08/02 Javascript
让JavaScript中setTimeout支持链式操作的方法
2015/06/19 Javascript
使用HTML+CSS+JS制作简单的网页菜单界面
2015/07/27 Javascript
浅谈angularjs module返回对象的坑(推荐)
2016/10/21 Javascript
Bootstrap Img 图片样式(推荐)
2016/12/13 Javascript
js获取元素下的第一级子元素的方法(推荐)
2017/03/05 Javascript
详解Vue 普通对象数据更新与 file 对象数据更新
2017/04/26 Javascript
js神秘的电报密码 哈弗曼编码实现
2019/09/10 Javascript
详解Vue 项目中的几个实用组件(ts)
2019/10/29 Javascript
Node.js API详解之 dgram模块用法实例分析
2020/06/05 Javascript
解决Vue中的生命周期beforeDestory不触发的问题
2020/07/21 Javascript
JS实现简易贪吃蛇游戏
2020/08/24 Javascript
python获取网页状态码示例
2014/03/30 Python
Python中的ctime()方法使用教程
2015/05/22 Python
详解Python3中的Sequence type的使用
2015/08/01 Python
Python数据结构与算法之使用队列解决小猫钓鱼问题
2017/12/14 Python
对python 多个分隔符split 的实例详解
2018/12/20 Python
python模块常用用法实例详解
2019/10/17 Python
linux 下python多线程递归复制文件夹及文件夹中的文件
2020/01/02 Python
Pycharm内置终端及远程SSH工具的使用教程图文详解
2020/03/19 Python
CSS3之transition实现下划线的示例代码
2018/05/30 HTML / CSS
html5 Canvas绘制线条 closePath()实例代码
2012/05/10 HTML / CSS
马来西亚和新加坡巴士票在线预订:CatchThatBus
2018/11/17 全球购物
Onzie官网:美国时尚瑜伽品牌
2019/08/21 全球购物
幼师自荐信
2013/10/26 职场文书
信用卡工资证明格式
2014/09/13 职场文书
博士给导师的自荐信
2015/03/06 职场文书
关于上班时间调整的通知
2015/04/23 职场文书
学生乘坐校车安全责任书
2015/05/11 职场文书
Python的这些库,你知道多少?
2021/06/09 Python
springboot 启动如何排除某些bean的注入
2021/08/02 Java/Android
Python之基础函数案例详解
2021/08/30 Python
gojs实现蚂蚁线动画效果
2022/02/18 Javascript