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 相关文章推荐
this[] 指的是什么内容 讨论
Mar 24 Javascript
IE 条件注释详解总结(附实例代码)
Aug 29 Javascript
理解Javascript_14_函数形式参数与arguments
Oct 20 Javascript
js点击更换背景颜色或图片的实例代码
Jun 25 Javascript
新增加的内容是如何将div的scrollbar自动移动最下面
Jan 02 Javascript
全面解析JavaScript的Backbone.js框架中的Router路由
May 05 Javascript
Node.js使用Koa搭建 基础项目
Jan 08 Javascript
微信小程序页面间值传递的两种方法
Nov 26 Javascript
vue+element-ui+axios实现图片上传
Aug 20 Javascript
javascript合并两个数组最简单的实现方法
Sep 14 Javascript
js+canvas实现五子棋小游戏
Aug 02 Javascript
nuxt 自定义 auth 中间件实现令牌的持久化操作
Nov 05 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获取客户端电脑屏幕参数的方法
2015/01/09 PHP
详解php用curl调用接口方法,get和post两种方式
2017/01/13 PHP
PHP PDOStatement::closeCursor讲解
2019/01/30 PHP
JavaScript 学习笔记之语句
2015/01/14 Javascript
javascript实现方法调用与方法触发小结
2016/03/26 Javascript
Angularjs---项目搭建图文教程
2016/07/08 Javascript
使用JSON作为函数的参数的优缺点
2016/10/27 Javascript
jQuery实现按比例缩放图片的方法
2017/04/29 jQuery
浅谈vue-router 路由传参的方法
2017/12/27 Javascript
vue-router跳转时打开新页面的两种方法
2019/07/29 Javascript
微信小程序如何实现radio单选框单击打勾和取消
2020/01/21 Javascript
在Vue中使用HOC模式的实现
2020/08/23 Javascript
PYTHON 中使用 GLOBAL引发的一系列问题
2016/10/12 Python
pandas string转dataframe的方法
2018/04/11 Python
python print 按逗号或空格分隔的方法
2018/05/02 Python
python日期时间转为字符串或者格式化输出的实例
2018/05/29 Python
python中单下划线_的常见用法总结
2018/07/10 Python
python format 格式化输出方法
2018/07/16 Python
python按键按住不放持续响应的实例代码
2019/07/17 Python
大数据分析用java还是Python
2020/07/06 Python
Python实现LR1文法的完整实例代码
2020/10/25 Python
HTML5 Canvas图像模糊完美解决办法
2018/02/06 HTML / CSS
分享全球十款超强HTML5开发工具
2014/05/14 HTML / CSS
英国潮流网站:END.(全球免邮)
2017/01/16 全球购物
Bravofly德国:预订廉价航班和酒店
2019/09/22 全球购物
行政人员岗位职责
2013/12/08 职场文书
计算机专业学生求职信分享
2013/12/15 职场文书
创业计划书怎样才能打动风投
2014/01/01 职场文书
元宵节晚会主持人串词
2014/03/25 职场文书
大班亲子运动会方案
2014/06/10 职场文书
公司离职证明范本(5篇)
2014/09/17 职场文书
县政府领导班子“四风”方面突出问题整改措施
2014/09/23 职场文书
装配出错检讨书
2014/09/23 职场文书
北京英语导游词
2015/02/12 职场文书
幼儿园庆六一主持词
2015/06/30 职场文书
两行代码解决Jupyter Notebook中文不能显示的问题
2021/04/24 Python