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插件开发方法(初学者)
Feb 03 Javascript
js关闭模态窗口刷新父页面或跳转页面
Dec 13 Javascript
得到form下的所有的input的js代码
Nov 07 Javascript
js实现刷新iframe的方法汇总
Apr 27 Javascript
AngularJS 如何在控制台进行错误调试
Jun 07 Javascript
微信小程序入门教程
Nov 18 Javascript
Angularjs中ng-repeat-start与ng-repeat-end的用法实例介绍
Dec 31 Javascript
Angularjs单选改为多选的开发过程及问题解析
Feb 17 Javascript
BootStrap fileinput.js文件上传组件实例代码
Feb 20 Javascript
vue 2.0组件与v-model详解
Mar 27 Javascript
详解vue slot插槽的使用方法
Jun 13 Javascript
vue使用better-scroll实现下拉刷新、上拉加载
Nov 23 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
精致的人儿就要挑杯子喝咖啡
2021/03/03 冲泡冲煮
PHP 地址栏信息的获取代码
2009/01/07 PHP
PHP数组操作简单案例分析
2016/10/15 PHP
laravel实现分页样式替换示例代码(增加首、尾页)
2017/09/22 PHP
CSS常用网站布局实例
2008/04/03 Javascript
23个Javascript弹出窗口特效整理
2011/02/25 Javascript
JavaScript回调(callback)函数概念自我理解及示例
2013/07/04 Javascript
第六章之辅组类与响应式工具
2016/04/25 Javascript
基于bootstrap实现广告轮播带图片和文字效果
2016/07/22 Javascript
Angularjs的Controller间通信机制实例分析
2016/11/07 Javascript
jQuery源码分析之sizzle选择器详解
2017/02/13 Javascript
js实现下一页页码效果
2017/03/07 Javascript
CentOS 安装NodeJS V8.0.0的方法
2017/06/15 NodeJs
vue项目中使用axios上传图片等文件操作
2017/11/02 Javascript
JS实现指定区域的全屏显示功能示例
2019/04/25 Javascript
[14:21]VICI vs EG (BO3)
2018/06/07 DOTA
python使用xmlrpc实例讲解
2013/12/17 Python
python实现根据图标提取分类应用程序实例
2014/09/28 Python
Python中join和split用法实例
2015/04/14 Python
Pyhton中单行和多行注释的使用方法及规范
2016/10/11 Python
Python Nose框架编写测试用例方法
2017/10/26 Python
Python中单、双下划线的区别总结
2017/12/01 Python
Python中一行和多行import模块问题
2018/04/01 Python
Python实现网站表单提交和模板
2019/01/15 Python
python实现统计代码行数的小工具
2019/09/19 Python
Python爬虫实现vip电影下载的示例代码
2020/04/20 Python
记一次高分屏下canvas模糊问题
2020/02/17 HTML / CSS
美国专业级皮肤病和spa品质护肤品的高级零售网站:SkinCareRx
2017/02/06 全球购物
高品质和独特的产品世界:Creations and Collections
2018/01/07 全球购物
Monki官网:斯堪的纳维亚的独立时尚品牌
2020/11/09 全球购物
应届生.NET方向面试题
2015/05/23 面试题
机械专业毕业生自我鉴定2014
2014/10/04 职场文书
四风批评与自我批评范文
2014/10/14 职场文书
计划生育工作汇报
2014/10/28 职场文书
2015医德医风个人工作总结
2015/04/02 职场文书
Python爬虫之爬取某文库文档数据
2021/04/21 Python