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 相关文章推荐
IE与Firefox下javascript getyear年份的兼容性写法
Dec 20 Javascript
JQuery 入门实例1
Jun 25 Javascript
js url传值中文乱码之解决之道
Nov 20 Javascript
js对象的构造和继承实现代码
Dec 05 Javascript
js与css实现弹出层覆盖整个页面的方法
Dec 13 Javascript
javascript实现鼠标点击页面 移动DIV
Dec 02 Javascript
详解基于webpack2.x的vue2.x的多页面站点
Aug 21 Javascript
详解Vue3.0 前的 TypeScript 最佳入门实践
Jun 18 Javascript
微信小程序实现消息框弹出动画
Apr 18 Javascript
关于JSON解析的实现过程解析
Oct 08 Javascript
Vue组件基础用法详解
Feb 05 Javascript
vue如何搭建多页面多系统应用
Jun 17 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
input file获得文件根目录简单实现
2013/04/26 PHP
PHP会员找回密码功能的简单实现
2016/09/05 PHP
php将服务端的文件读出来显示在web页面实例
2016/10/31 PHP
PHP实现打包下载文件的方法示例
2017/10/07 PHP
PHP+AJAX 投票器功能
2017/11/11 PHP
PHP图像处理 imagestring添加图片水印与文字水印操作示例
2020/02/06 PHP
分享20多个很棒的jQuery 文件上传插件或教程
2011/09/04 Javascript
ASP.NET jQuery 实例18 通过使用jQuery validation插件校验DropDownList
2012/02/03 Javascript
JavaScript自执行闭包的小例子
2013/06/29 Javascript
一个JS函数搞定网页标题(title)闪动效果
2014/05/13 Javascript
js键盘事件的keyCode
2014/07/29 Javascript
node.js中的querystring.parse方法使用说明
2014/12/10 Javascript
IE下支持文本框和密码框placeholder效果的JQuery插件分享
2015/01/31 Javascript
js正则匹配出所有图片及图片地址src的方法
2015/06/08 Javascript
JS简单实现多级Select联动菜单效果代码
2015/09/06 Javascript
全面解析Bootstrap弹窗的实现方法
2015/12/01 Javascript
jquery实现静态搜索功能(可输入搜索文字)
2017/03/28 jQuery
如何在postman中添加cookie信息步骤解析
2020/06/30 Javascript
在vue-cli3中使用axios获取本地json操作
2020/07/30 Javascript
python如何查看系统网络流量的信息
2016/09/12 Python
python3.6 +tkinter GUI编程 实现界面化的文本处理工具(推荐)
2017/12/20 Python
Python断言assert的用法代码解析
2018/02/03 Python
python实现隐马尔科夫模型HMM
2018/03/25 Python
详解Django 中是否使用时区的区别
2018/06/14 Python
python复制列表时[:]和[::]之间有什么区别
2018/10/16 Python
python3实现多线程聊天室
2018/12/12 Python
Tensorflow的常用矩阵生成方式
2020/01/04 Python
纯css实现照片墙3D效果的示例代码
2017/11/13 HTML / CSS
杰夫·班克斯男士服装网上商店:Jeff Banks
2019/10/24 全球购物
英国豪华装饰照明品牌的在线零售商:Inspyer Lighting
2019/12/10 全球购物
Linux不知道文件后缀名怎么判断文件类型
2014/08/21 面试题
《要下雨了》教学反思
2014/02/17 职场文书
五四青年节演讲稿
2014/05/26 职场文书
高中课前三分钟演讲稿
2014/08/18 职场文书
2015年上半年党建工作总结
2015/03/30 职场文书
Python中的tkinter库简单案例详解
2022/01/22 Python