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 相关文章推荐
javascript操作Cookie(设置、读取、删除)方法详解
Mar 18 Javascript
javascript使用avalon绑定实现checkbox全选
May 06 Javascript
Javascript 计算字符串在localStorage中所占字节数
Oct 21 Javascript
微信小程序 下拉列表的实现实例代码
Mar 08 Javascript
jquery在启动页面时,自动加载数据的实例
Jan 22 jQuery
node+koa2+mysql+bootstrap搭建一个前端论坛
May 06 Javascript
node 命令方式启动修改端口的方法
May 12 Javascript
vue文件运行的方法教学
Feb 12 Javascript
原生js代码能实现call和bind吗
Jul 31 Javascript
vue遍历生成的输入框 绑定及修改值示例
Oct 30 Javascript
vue.js+element 默认提示中英文操作
Nov 11 Javascript
VUE中鼠标滚轮使div左右滚动的方法详解
Dec 14 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 gd2 上传图片/文字水印/图片水印/等比例缩略图/实现代码
2010/05/15 PHP
php实现学生管理系统
2020/03/21 PHP
php中str_pad()函数用法分析
2017/03/28 PHP
php大小写转换函数(strtolower、strtoupper)用法介绍
2017/11/17 PHP
thinkphp5.1 框架钩子和行为用法实例分析
2020/05/25 PHP
form中限制文本字节数js代码
2007/06/10 Javascript
jquery创建div 实现代码
2009/04/27 Javascript
JS+DIV+CSS排版布局实现美观的选项卡效果
2015/10/10 Javascript
基于jQuery实现的无刷新表格分页实例
2016/02/17 Javascript
深入浅出ES6新特性之函数默认参数和箭头函数
2016/08/01 Javascript
js实现的页面加载完毕之前loading提示效果完整示例【附demo源码下载】
2016/08/02 Javascript
Javascript 创建类并动态添加属性及方法的简单实现
2016/10/20 Javascript
使用vue构建一个上传图片表单
2017/07/04 Javascript
vue iview组件表格 render函数的使用方法详解
2018/03/15 Javascript
vue-cli3使用 DllPlugin 实现预编译提升构建速度
2019/04/24 Javascript
django反向解析和正向解析的方式
2018/06/05 Python
PyCharm设置SSH远程调试的方法
2018/07/17 Python
浅谈python中str字符串和unicode对象字符串的拼接问题
2018/12/04 Python
Python常用模块之requests模块用法分析
2019/05/15 Python
PyCharm更改字体和界面样式的方法步骤
2019/09/27 Python
pandas中的数据去重处理的实现方法
2020/02/10 Python
Xadmin+rules实现多选行权限方式(级联效果)
2020/04/07 Python
20行Python代码实现视频字符化功能
2020/04/13 Python
美国最古老的精致书写工具制造商:A.T. Cross(高仕)
2018/01/30 全球购物
Parfume Klik丹麦:香水网上商店
2018/07/10 全球购物
Johnson Fitness澳大利亚:高级健身器材
2021/03/16 全球购物
表决心的诗句大全
2014/03/11 职场文书
交通事故委托书范本精选
2014/10/04 职场文书
2014年老干部工作总结
2014/11/21 职场文书
2015年保送生自荐信
2015/03/24 职场文书
2016年大学生社区服务活动总结
2016/04/06 职场文书
小公司融资,商业计划书的8切记
2019/07/15 职场文书
详解Redis主从复制实践
2021/05/19 Redis
vue 给数组添加新对象并赋值
2022/04/20 Vue.js
微软官方消息,在 2023 年 4 月 11 日之后微软将不再为 Office 2013 和 Skype for Business 2015 提供安全更新
2022/04/21 数码科技
阿里云服务器(windows)手动部署FTP站点详细教程
2022/08/05 Servers