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
}