IOS和android交互

第一次做和原生app的混合开发,其中有一些活动页面需要我这边用h5来做。

那么必定涉及一个问题。就是和原生app做交互。

分为ios和android。方法不同,逻辑思路都差不多。

大体思路就是我和app端约定一个方法,类似于?接头暗号?

比如说我们约定了一个方法:’蓝天白云‘,那么当我js调用这个方法的时候,app端通过'蓝天白云',认出了我,并作出了响应。

那么问题来了,很多同学(大概只有我自己)会说了,我原生js定义的函数,他app怎么调用,怎么知道我调了改方法。

****和app端沟通以后,原来app中的底层,或者框架里,会定义一个方法来接受我们的js函数****(这里不用管,我们只要管我们调用什么方法就可以了)

上代码

           //定义传的参数
          let sendData = {
                url: "articleDetail",
                id: v.id
            };
             //判断运行环境(搜一下)
            if (this.isiOS) {
       //解释一下,这里定义的window.xxxx什么方法,我们的window对象下是没有这个方法的,只有当我们的程序,运行到了适当的环境中,app会给我们的window对象添加这个方法,让我们可以调用,所以用了try防止报错
   //下面的callIos和callAndroid就是我和app大兄弟约定的方法
                try {
                    window.webkit.messageHandlers.callIos.postMessage(
                        JSON.stringify(sendData)
                    );
                } catch (e) {}
            } else {
                try {
                    window.jsInterface.invokeMethod("callAndroid", [
                        JSON.stringify(sendData)
                    ]);
                } catch (e) {}
            }

 

转载于:https://my.oschina.net/u/3883810/blog/3098362

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值