You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

如何检测Chrome 83浏览器?求适配该版本的React检测代码

适配Chrome 72+的浏览器检测方案

嗨,我完全懂你的烦恼——旧的检测代码在新版本Chrome里失效确实挺闹心的。咱们先说说为什么原来的代码不行:

// Chrome 1 - 71
const isChrome = !!window.chrome && (!!window.chrome.webstore || !!window.chrome.runtime);

这段代码依赖window.chrome.webstorewindow.chrome.runtime这两个属性,但Chrome 72版本之后,官方调整了这些属性的暴露逻辑,常规浏览环境下可能不再能访问到它们,所以导致你的Chrome 83无法被检测到。

这里给你两个适配新版本的检测方案,按需选择:

方案一:简洁版检测

结合window.chrome的存在和User Agent信息,同时排除基于Chromium的Edge浏览器(因为新Edge也会带有window.chrome对象):

const isChrome = !!window.chrome && /Chrome/.test(navigator.userAgent) && !/Edg/.test(navigator.userAgent);

方案二:更严谨的函数式检测

如果需要更清晰的逻辑或者后续扩展,可以封装成函数:

function isChrome() {
  // 确认是Chromium内核浏览器
  const isChromiumBased = !!window.chrome;
  // 排除Edge浏览器(新Edge的UA会包含"Edg"标识)
  const isNotEdge = !/Edg/i.test(navigator.userAgent);
  // 额外验证Chrome的UA标识
  const hasChromeUA = /Chrome/i.test(navigator.userAgent);

  return isChromiumBased && isNotEdge && hasChromeUA;
}

额外提醒

其实尽量优先使用特性检测而非浏览器检测会更可靠——比如你如果是为了兼容某个Chrome特有的API,直接检测该API是否存在(比如if ('someAPI' in window)),而不是检测浏览器版本。毕竟浏览器更新迭代快,检测代码很容易随着版本失效。不过如果确实需要明确检测Chrome,上面的方案可以适配到目前的新版本(包括你的83版本,以及后续的多数版本)。

内容的提问来源于stack exchange,提问作者Rub Play

火山引擎 最新活动