客戶端(Android、ios)與 H5交互

1、首先Android、ios 內核不一樣,需要對Android和ios做不同的處理

a.判斷內核的方法:

const browser = () => {
   let u = navigator.userAgent;
  return {
    trident: u.indexOf('Trident') > -1, //IE內核
    presto: u.indexOf('Presto') > -1, //opera內核
    webKit: u.indexOf('AppleWebKit') > -1, //蘋果、谷歌內核
    gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐內核
    mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否爲移動終端
    ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios終端
    android: u.indexOf('Android') > -1 || u.indexOf('Adr') > -1, //android終端
    iPhone: u.indexOf('iPhone') > -1, //是否爲iPhone或者QQHD瀏覽器
    iPad: u.indexOf('iPad') > -1, //是否iPad
    webApp: u.indexOf('Safari') == -1, //是否web應該程序,沒有頭部與底部
    weixin: u.indexOf('MicroMessenger') > -1, //是否微信 (2015-01-22新增)
    qq: u.match(/\sQQ/i) == " qq" //是否QQ
  }
}

 判斷 是否爲 Android : browser.android 返回 true或者 false

判斷是否爲 ios: browser.iPhone 返回 true或者 false

2、通過js出發客戶端方法:

Android : window.messageHandlers

ios:window.webkit.messageHandlers

  window.messageHandlers.hrefApp(JSON.stringify({  //hrefApp是原生爲Handlers起的別名
      path: 'get_token' //跟客戶端協議
    }))
    window.getToken = function (str) {  //getToken:跟原生定的獲取token方法
      alert(str);  //str 爲token

    }

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章