有些时候,咱们在开发过程当中须要判断,当前页面被打开是不是处于源生的webview里面,或者NODEJS作服务器后端支持的时候,判断请求来源是否来至于源生webview里面被打开的页面请求GET/POST/.. 因而写了一个轮子,用javascript的形式判断当前设备android或者ios,是否是又webview来装载页面内容 仍是 浏览器(非webview)来装载页面内容。javascript
js-is-webview
github:https://github.com/wuliqiangqiang/is-webviewjava
use javascrupt to know it is webview ? support node and the browser(webpack) pass User-Agent sniffing,know the HTTP/HTTPS request is performed by a UIWebview/Webview or not.node
安装
npm install js-is-webview --save
Node 服务端的用法
const isWebview = require("js-is-webview"); const is_webview = new isWebview(); const server = (req, res, next) => { - let userAgent = { - userAgent:req.headers['User-Agent'] } // if true if(isWebview.check(userAgent))){ //... next(); } };
浏览器 的用法
const isWebview = require("js-is-webview"); const is_webview = new isWebview(); let userAgent = { userAgent:navigator.userAgent } if(isWebview.check(userAgent))){ //... }
API
惟一API方法,检查是否来自webviewandroid
iswebview.check({userAgent})
userAgent
(Object.key): Browser User-Agent header string
if(isWebview.check({userAgent}))){ //... }
iswebview.check({userAgent, configObject})
userAgent
(Object.key): Browser User-Agent header string - 浏览器标识configObject
(Object)appName
(String): the app name explicitly set in your WebView properties/settings. -在WebView属性/设置中显式设置的应用程序名称。