| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 移动开发 -> 记录工作中h5与原生App通讯的方式 -> 正文阅读 |
|
[移动开发]记录工作中h5与原生App通讯的方式 |
在使用vue开发的h5网页嵌套app中,与原生app要怎么进行通讯呢?本文记录一下开发中的小技巧。 /** ?*?H5与原生通信(不需要引入第三方库) ?*?@param?fnName?方法名称(原生与H5中需要一致)?getParameters?|?logOut ?*?@param?callback?获取的数据回调 ?*/ export?const?sendNativeMessage?=?(fnName,?callback)?=>?{ ? //?获取系统信息,ios还是安卓 ??const?u?=?navigator.userAgent; ??const?isIos?=?!!u.match(/\(i[^;]+;(?U;)??CPU.+Mac?OS?X/);?//ios终端 ??const?isAndroid?=?u.indexOf('Android')?>?-1?||?u.indexOf('Linux')?>?-1; ??if?(isIos)?{ ????const?iOSCallback?=?`iOSCallback${new?Date().valueOf()}`; ????if?(fnName?===?'getParameters')?{ ????????window[iOSCallback]?=?(resString?=?'')?=>?{ ????????????callback?&&?callback(JSON.parse(decodeURIComponent(resString))); ????????????delete?window.iOSCallback; ????????}; ????} ????const?data?=?{ ??????callback:?iOSCallback ????}; ????//?IOS环境使用方法 ????window.webkit?&& ????????window.webkit.messageHandlers?&& ????????window.webkit.messageHandlers[fnName]?&& ????????window.webkit.messageHandlers[fnName].postMessage(encodeURIComponent(JSON.stringify(data))); ??} ??if?(isAndroid)?{ ????//?安卓使用方法 ????let?resString?=?window.bigMemberApp?&&?window.bigMemberApp[fnName]?&&?window.bigMemberApp[fnName](); ????callback?&&?callback(JSON.parse(resString)); ??} }; 调用方式 ?sendNativeMessage('getParameters',?res?=>?{ // 需要获取的字段名称 const?params?= ?["authorization",?"propertyProjectId",?"propertyProjectName",?"account",?"accountID"]?; ??????params.forEach(item?=>?{ ????????setStorerage(item?,?res[item]) ??????}) ????}); 小伙伴们如果有更好的方式欢迎留言互相交流!!!! |
|
移动开发 最新文章 |
Vue3装载axios和element-ui |
android adb cmd |
【xcode】Xcode常用快捷键与技巧 |
Android开发中的线程池使用 |
Java 和 Android 的 Base64 |
Android 测试文字编码格式 |
微信小程序支付 |
安卓权限记录 |
知乎之自动养号 |
【Android Jetpack】DataStore |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/28 12:07:04- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |