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中name的意义冲突示例介绍
May 29 Javascript
JS数组的常见用法实例
Feb 10 Javascript
zepto中使用swipe.js制作轮播图附swipeUp,swipeDown不起效果问题
Aug 27 Javascript
jQuery采用连缀写法实现的折叠菜单效果
Sep 18 Javascript
使用PHP+JavaScript将HTML页面转换为图片的实例分享
Apr 18 Javascript
json传值以及ajax接收详解
May 24 Javascript
jQuery+CSS3实现仿花瓣网固定顶部位置带悬浮效果的导航菜单
Sep 21 Javascript
jquery实现简单的瀑布流布局
Dec 11 Javascript
React快速入门教程
Jan 17 Javascript
使用jQuery实现鼠标点击左右按钮滑动切换
Aug 04 jQuery
vue webpack实用技巧总结
Apr 24 Javascript
Vue与React的区别和优势对比
Dec 18 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抽象工厂模式(Elgg)
2010/03/21 PHP
Joomla实现组件中弹出一个模式(modal)窗口的方法
2016/05/04 PHP
ThinkPHP框架实现定时执行任务的两种方法分析
2018/09/04 PHP
JTrackBar水平拖动效果
2007/07/15 Javascript
JavaScript Date对象使用总结
2009/05/14 Javascript
javascript 特性检测并非浏览器检测
2010/01/15 Javascript
精通Javascript系列之Javascript基础篇
2011/06/07 Javascript
扩展IE中一些不兼容的方法如contains、startWith等等
2014/01/09 Javascript
javascript根据像素点取位置示例
2014/01/27 Javascript
js获取鼠标点击的位置实现思路及代码
2014/05/09 Javascript
JavaScript中伪协议 javascript:使用探讨
2014/07/18 Javascript
js插件设置innerHTML时在IE8下提示“未知运行时错误”解决方法
2015/04/25 Javascript
浅析JavaScript中的变量复制、参数传递和作用域链
2016/01/13 Javascript
JavaScript实现向select下拉框中添加和删除元素的方法
2017/03/07 Javascript
JavaScript实现简单的双色球(实例讲解)
2017/07/31 Javascript
解决vue处理axios post请求传参的问题
2018/03/05 Javascript
layui实现根据table数据判断按钮显示情况的方法
2019/09/26 Javascript
AngularJS动态生成select下拉框的方法实例
2019/11/17 Javascript
Vue全局使用less样式,组件使用全局样式文件中定义的变量操作
2020/10/21 Javascript
nodejs中内置模块fs,path常见的用法说明
2020/11/07 NodeJs
Python中urllib2模块的8个使用细节分享
2015/01/01 Python
python中is与双等于号“==”的区别示例详解
2017/11/21 Python
python模拟表单提交登录图书馆
2018/04/27 Python
Python collections中的双向队列deque简单介绍详解
2019/11/04 Python
Pytorch.nn.conv2d 过程验证方式(单,多通道卷积过程)
2020/01/03 Python
python numpy实现rolling滚动案例
2020/06/08 Python
加拿大专业美发产品购物网站:Chatters
2021/02/28 全球购物
PHP开发的一般流程
2013/08/13 面试题
给女朋友的道歉信
2014/01/10 职场文书
护士自我评价
2014/02/01 职场文书
圣诞节活动策划方案
2014/06/09 职场文书
党建工作整改措施
2014/10/28 职场文书
客户答谢会致辞
2015/07/30 职场文书
2016秋季运动会开幕词
2016/03/04 职场文书
MySQL单表千万级数据处理的思路分享
2021/06/05 MySQL
PyMongo 查询数据的实现
2021/06/28 Python