摘要:三调用方法与不同之处在于,接收中文英文参数,无需操作。例如,我想要获取用户,本着驼峰命名规范,我们将函数名称统一定义为。在调试时,发现接收到的函数方法为,导致。
写在前面的话:本文面向web前端工程师,iOS 或 Android 请移步这里stackoverflow。关于app开发模式,这里不再赘述。
一、判断机型js 调用 Native iOS/Android function 需要使用不同的方法,所以首先要做的是判断用户机型,代码如下:
var u = navigator.userAgent.toLowerCase(); var isApple = /iphone|ipad|ipod|ios/i.test(u); var isAndroid = /android/i.test(u);二、调用 Native iOS 方法
通过 js 改变 window.location 值, 来实现调用 iOS function ,这个操作并不是跳转,而是触发了一个 即发即弃 (a fire and forget) 事件。代码如下:
//一个参数 window.location = "color://" + color; //两个参数 window.location = "myscheme://param1/" + value1 + "/param2/" + value2;
iOS 端接收参数需要进行 url 编码处理,可以使用 encodeURIComponent 函数处理。
ps:关于URI和URL
URI(Uniform Resource Identifier) 统一资源标识符
URL(Uniform Resource Locator) 统一资源定位符
URI包含URL和URN,如果URI标识一个人,URL好比这个人的住址,URN则是名字。
与 iOS 不同之处在于,Andriod 接收中文英文参数,无需 encode 操作。实现代码如下:
if(window.AndroidBridge) { window.AndroidBridge.changeNavbarBackground(color); }四、关于函数名称约定
三方会根据业务需求定义一个通用的函数名称,这个函数名称通常是由web前端工程师定义的。例如,我想要获取用户id,本着驼峰命名规范,我们将函数名称统一定义为 getId() 。在 iOS 调试时,发现iOS接收到的函数方法为 getid() ,导致bug。
ok,问题解决了,若还有其他问题,欢迎给我留言。如果对你有帮助,记得在下方点个推荐吧~~
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/50253.html
摘要:三调用方法与不同之处在于,接收中文英文参数,无需操作。例如,我想要获取用户,本着驼峰命名规范,我们将函数名称统一定义为。在调试时,发现接收到的函数方法为,导致。 写在前面的话:本文面向web前端工程师,iOS 或 Android 请移步这里stackoverflow。关于app开发模式,这里不再赘述。 一、判断机型 js 调用 Native iOS/Android function 需...
摘要:三调用方法与不同之处在于,接收中文英文参数,无需操作。例如,我想要获取用户,本着驼峰命名规范,我们将函数名称统一定义为。在调试时,发现接收到的函数方法为,导致。 写在前面的话:本文面向web前端工程师,iOS 或 Android 请移步这里stackoverflow。关于app开发模式,这里不再赘述。 一、判断机型 js 调用 Native iOS/Android function 需...
阅读 3816·2021-10-09 09:43
阅读 2843·2021-10-08 10:05
阅读 2717·2021-09-08 10:44
阅读 854·2019-08-30 15:52
阅读 2778·2019-08-26 17:01
阅读 2980·2019-08-26 13:54
阅读 1632·2019-08-26 10:48
阅读 789·2019-08-23 14:41