小伙伴们在用vue开发h5项目特别是移动端的项目,很多都是打包后挂载在原生APP上的,那就少不了与原生交互了,我最近就是在坐这个,踩了一些坑,拿出来给大家分享下。
1 methods: { 2 // 接收url后的数据 3 urltext() { 4 let loc = location.href; 6 let n1 = loc.length;//地址的总长度 7 let n2 = loc.indexOf("=");//取得=号的位置 8 let outToken = loc.substr(n2 + 1, n1 - n2);//从=号后面的内容 9 console.log(loc,n1,n2,outToken) 10 this.outTokenPost(outToken) //传到处理函数 11 }, 12 }
思路就是万物通过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) },
}
原文:https://www.cnblogs.com/nogodie/p/10029858.html