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 相关文章推荐
js以对象为索引的关联数组
Jul 04 Javascript
JS维吉尼亚密码算法实现代码
Nov 09 Javascript
js验证真实姓名与身份证号是否匹配
Oct 13 Javascript
jQuery自定义动画函数实例详解(附demo源码)
Dec 10 Javascript
jQuery each函数源码分析
May 25 Javascript
轻松5句话解决JavaScript的作用域
Jul 15 Javascript
详谈jQuery中的一些正则匹配表达式
Mar 08 Javascript
bootstrap confirmation按钮提示组件使用详解
Aug 22 Javascript
学习jQuery中的noConflict()用法
Sep 28 jQuery
使用pm2部署node生产环境的方法步骤
Mar 09 Javascript
微信小程序云开发之使用云函数
May 17 Javascript
通过实例解析JavaScript常用排序算法
Sep 02 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
下拉列表多级联动dropDownList示例代码
2013/06/27 PHP
Zend Framework教程之请求对象的封装Zend_Controller_Request实例详解
2016/03/07 PHP
PHP云打印类完整示例
2016/10/15 PHP
如何直接访问php实例对象中的private属性详解
2017/10/12 PHP
YII框架http缓存操作示例
2019/04/29 PHP
一个选择最快的服务器转向代码
2009/04/27 Javascript
基于jquery的关于动态创建DOM元素的问题
2010/12/24 Javascript
可兼容IE的获取及设置cookie的jquery.cookie函数方法
2013/09/02 Javascript
2014最热门的JavaScript代码高亮插件推荐
2014/11/25 Javascript
JavaScript对象数组排序函数及六个用法
2015/12/23 Javascript
Jquery中map函数的用法
2016/06/03 Javascript
Query常用DIV操作获取和设置长度宽度的实现方法
2016/09/19 Javascript
Angular和Vue双向数据绑定的实现原理(重点是vue的双向绑定)
2016/11/22 Javascript
bootstrap输入框组使用方法
2017/02/07 Javascript
Node.js模块全局安装路径配置方法
2018/05/17 Javascript
微信小程序左滑删除功能开发案例详解
2018/11/12 Javascript
JavaScript栈和队列相关操作与实现方法详解
2018/12/07 Javascript
浅谈Vue.js之初始化el以及数据的绑定说明
2019/11/14 Javascript
python使用正则表达式分析网页中的图片并进行替换的方法
2015/03/26 Python
Python中文件操作简明介绍
2015/04/13 Python
一步步教你用Python实现2048小游戏
2017/01/19 Python
Python2包含中文报错的解决方法
2018/07/09 Python
django中使用POST方法获取POST数据
2019/08/20 Python
教你使用Canvas处理图片的方法
2017/11/28 HTML / CSS
英国家居装饰品、户外家具和玻璃器皿购物网站:Rinkit.com
2019/11/04 全球购物
阿里巴巴的Oracle DBA笔试题答案-SQL tuning类
2016/04/03 面试题
大学中国梦演讲稿
2014/04/23 职场文书
人身意外保险授权委托书
2014/10/01 职场文书
2014年个人工作总结报告
2014/11/27 职场文书
2015年党支部公开承诺书
2015/01/22 职场文书
胡雪岩故居导游词
2015/02/06 职场文书
加班费申请报告
2015/05/15 职场文书
实习单位意见
2015/06/04 职场文书
导游词之吉林吉塔
2019/11/11 职场文书
tree shaking对打包体积优化及作用
2022/07/07 Java/Android
vue递归实现树形组件
2022/07/15 Vue.js