Vue.js暴露方法给WebView的使用操作


Posted in Javascript onSeptember 07, 2020

新建一个外部公共的js文件app.js,定义一个对象并输出,如下:

var hybrid = { 
}
 
window.Hybrid = hybrid
 
if (window.Vue) {
 window.Vue.use(hybrid)
}
 
export { hybrid }

在需要的文件中引入app.js或者在main.js引入app.js,如下(引入到main.js):

import { hybrid } from './common/app'

Vue.prototype.$hybrid = hybrid

将需要暴露的方法赋给hybrid对象,如下:

Vue.js暴露方法给WebView的使用操作

补充知识:将Vue项目methods中的方法暴露在window上

我是一个H5,咱们在写APP的时候,也就是APP内部嵌套咱们H5代码的时候,肯定会遇到交互问题,如果使用普通html js css的话应该没有什么太大的问题,因为普通js方法都是暴露在window上面的,就我们公司的APP,使用回调的时候会在window上面找H5回调方法,

代码这个样子的

mounted() {
   // 将backToday方法绑定到window下面,提供给外部调用
   let me = this;
   window['logoClickBtn'] = (url) => {
     // Toast({ message: url, position: 'bottom', duration: 5000 });
     me.logoClickBtn(url)
   }
 },

然后我写一下大概步骤是啥样的 ,不然你只知道这样写,但是上一步的操作是什么

Vue.js暴露方法给WebView的使用操作

这方法肯定有触发条件,再触发的时候将参数进行传入,与APP对接成功之后,会将再次调用咱们的函数也就是callBack,

我项目中是因为要是有手机中的拍照与手机图片上传,在咱们的页面中应该是这个样子的在这里插入图片描述

Vue.js暴露方法给WebView的使用操作

代码是这个样子的

Vue.js暴露方法给WebView的使用操作

Vue.js暴露方法给WebView的使用操作

当与APP对接成功之后就会调用咱们传过去的方法名了,但是APP端调用咱们的方法都是绑定在window上面的方法,故咱们应该讲咱们的方法暴露在window上面,因为Vue项目中的this指向vue,而不是window,

代码是这个样子的

mounted() {
     // 将backToday方法绑定到window下面,提供给外部调用
     let me = this;
     window['logoClickBtn'] = (url) => {
       me.logoClickBtn(url); // 这个也就是我定义的方法
     }
   },

这一步是什么呢?就是APP会给咱们上传的图片的一个路径,然后使用这个路径在进行下一步操作,也就是

logoClickBtn(url) {
     this.form.logo = url; // 进行数据驱动试图
   },

然后咱们的页面上就会有图片了

Vue.js暴露方法给WebView的使用操作

因为服务没有开,所以就不展示了 哈哈,这个步骤是可以走通的。

以上这篇Vue.js暴露方法给WebView的使用操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
对之前写的jquery分页做下升级
Jun 19 Javascript
jQuery仿Flash上下翻动的中英文导航菜单实例
Mar 10 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
Aug 21 Javascript
node.js操作mysql简单实例
May 25 Javascript
ReactNative实现Toast的示例
Dec 31 Javascript
element-ui上传一张图片后隐藏上传按钮功能
May 22 Javascript
vue分页器组件编写方法详解
Jun 28 Javascript
Vue 实现输入框新增搜索历史记录功能
Oct 15 Javascript
微信小程序如何实现点击图片放大功能
Jan 21 Javascript
解决echarts中横坐标值显示不全(自动隐藏)问题
Jul 20 Javascript
vuex分模块后,实现获取state的值
Jul 26 Javascript
解决vue路由name同名,路由重复的问题
Aug 05 Javascript
三步搞定:Vue.js调用Android原生操作
Sep 07 #Javascript
vue单应用在ios系统中实现微信分享功能操作
Sep 07 #Javascript
vue 微信分享回调iOS和安卓回调出现错误的解决
Sep 07 #Javascript
一篇文章带你从零快速上手Rollup
Sep 07 #Javascript
基于vue hash模式微信分享#号的解决
Sep 07 #Javascript
在项目vue中使用echarts的操作步骤
Sep 07 #Javascript
解决vue加scoped后就无法修改vant的UI组件的样式问题
Sep 07 #Javascript
You might like
Trying to clone an uncloneable object of class Imagic的解决方法
2012/01/11 PHP
php页面,mysql数据库转utf-8乱码,utf-8编码问题总结
2015/08/27 PHP
PHP实现QQ登录实例代码
2016/01/14 PHP
Laravel接收前端ajax传来的数据的实例代码
2017/07/20 PHP
JS代码优化技巧之通俗版(减少js体积)
2011/12/23 Javascript
在javascript中对于DOM的加强
2013/04/11 Javascript
简介JavaScript中getUTCMonth()方法的使用
2015/06/10 Javascript
下雪了 javascript实现雪花飞舞
2020/08/02 Javascript
深入浅析JS是按值传递还是按引用传递(推荐)
2016/09/18 Javascript
JS扩展类,克隆对象与混合类实例分析
2016/11/26 Javascript
JS中用childNodes获取子元素换行会产生一个子元素
2016/12/08 Javascript
浅谈JavaScript中promise的使用
2017/01/11 Javascript
JS如何设置元素样式的方法示例
2017/08/28 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
如何基于viewport vm适配移动端页面
2020/11/13 Javascript
解读Python中degrees()方法的使用
2015/05/18 Python
python链接oracle数据库以及数据库的增删改查实例
2018/01/30 Python
Python生成器以及应用实例解析
2018/02/08 Python
Python爬虫实战:分析《战狼2》豆瓣影评
2018/03/26 Python
python实现五子棋人机对战游戏
2020/03/25 Python
Python 元组操作总结
2019/09/18 Python
解决Tensorboard可视化错误:不显示数据 No scalar data was found
2020/02/15 Python
基于pygame实现童年掌机打砖块游戏
2020/02/25 Python
使用python matplotlib 画图导入到word中如何保证分辨率
2020/04/16 Python
Django-migrate报错问题解决方案
2020/04/21 Python
基于Python+QT的gui程序开发实现
2020/07/03 Python
HTML5 canvas基本绘图之绘制曲线
2016/06/27 HTML / CSS
开普敦通行证:Cape Town Pass
2019/07/18 全球购物
.NET面试题:什么是值类型和引用类型
2016/01/12 面试题
介绍一下gcc特性
2015/10/31 面试题
大学生自我鉴定
2013/12/16 职场文书
即将毕业大学生自荐信
2014/01/24 职场文书
我的梦中国梦演讲稿
2014/04/23 职场文书
学生干部培训方案
2014/06/12 职场文书
学习礼仪心得体会
2014/09/01 职场文书
领导干部遵守党的政治纪律情况思想汇报
2014/09/14 职场文书