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动画animate的stop方法使用详解
May 09 Javascript
使用jquery实现放大镜效果
Sep 02 Javascript
JavaScript简单实现弹出拖拽窗口(一)
Jun 17 Javascript
BootStrap的两种模态框方式
May 10 Javascript
详解VueJs前后端分离跨域问题
May 24 Javascript
浅谈react+es6+webpack的基础配置
Aug 09 Javascript
关于在mongoose中填充外键的方法详解
Aug 14 Javascript
Vue.js 中的 v-cloak 指令及使用详解
Nov 19 Javascript
解决使用layui对select append元素无效或者未及时更新的问题
Sep 18 Javascript
小程序最新获取用户昵称和头像的方法总结
Sep 23 Javascript
vue实现权限控制路由(vue-router 动态添加路由)
Nov 04 Javascript
Vue实现简单计算器案例
Feb 25 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
全国FM电台频率大全 - 10 江苏省
2020/03/11 无线电
PHP 面向对象程序设计(oop)学习笔记 (四) - 异常处理类Exception
2014/06/12 PHP
PHP常见错误提示含义解释(实用!值得收藏)
2016/04/25 PHP
php生成图片缩略图功能示例
2017/02/22 PHP
PHP将身份证正反面两张照片合成一张图片的代码
2017/04/08 PHP
Yii框架批量插入数据扩展类的简单实现方法
2017/05/23 PHP
PHP与JavaScript针对Cookie的读写、交互操作方法详解
2017/08/07 PHP
php mysql PDO 查询操作的实例详解
2017/09/23 PHP
php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法分析
2019/06/25 PHP
从阿里妈妈发现的几个不错的表单验证函数
2007/09/21 Javascript
用js实现判断当前网址的来路如果不是指定的来路就跳转到指定页面
2011/05/02 Javascript
js 数值转换为3位逗号分隔的示例代码
2014/02/19 Javascript
Jquery弹出层插件ThickBox的使用方法
2014/12/09 Javascript
js中split和replace的用法实例
2015/02/28 Javascript
CSS+JS实现点击文字弹出定时自动关闭DIV层菜单的方法
2015/05/12 Javascript
js+html5实现canvas绘制圆形图案的方法
2015/06/05 Javascript
分享两段简单的JS代码防止SQL注入
2016/04/12 Javascript
[02:40]DOTA2英雄基础教程 炼金术士
2013/12/23 DOTA
[10:39]DOTA2上海特级锦标赛音乐会纪录片
2016/03/21 DOTA
python多线程编程方式分析示例详解
2013/12/06 Python
轻松掌握python设计模式之策略模式
2016/11/18 Python
在Python中通过getattr获取对象引用的方法
2019/01/21 Python
python实现五子棋小程序
2019/06/18 Python
Python实现直方图均衡基本原理解析
2019/08/08 Python
使用AJAX和Django获取数据的方法实例
2020/10/25 Python
详解canvas.toDataURL()报错的解决方案全都在这了
2020/03/31 HTML / CSS
碧欧泉Biotherm加拿大官方网站:法国高端护肤品牌
2019/10/18 全球购物
通信工程专业个人找工作求职信范文
2013/09/21 职场文书
商场总经理岗位职责
2014/02/03 职场文书
教师年度考核评语
2014/04/28 职场文书
地震捐款倡议书
2014/08/29 职场文书
公司领导班子对照检查存在问题整改措施
2014/10/02 职场文书
高二语文教学反思
2016/02/16 职场文书
七年级思品教学反思
2016/02/20 职场文书
入党申请书怎么写?
2019/06/21 职场文书
MySQL数据库完全卸载的方法
2022/03/03 MySQL