浏览器功能检测/是否支持

今天推荐一个开源的库, 它能够检测用户浏览器是否支持某些特性和功能, 不是通过 UA 去检测,毕竟UA 在一定程度上是带有欺骗性的。

Modernizr Documentation

Modernizr 是一小段 JavaScript 代码,可自动检测用户浏览器中下一代 Web 技术的可用性。Modernizr 不是根据"UA 嗅探"将整个浏览器系列列入黑名单,而是使用功能检测,让您根据浏览器的实际功能轻松定制用户体验。

当用户浏览器/环境 不支持某个较新的js 语法/css用法 时,能使用备用方案

js 复制代码
if(用户浏览器支持的语法) {
    // 业务逻辑
} else {
    //不支持的时候,兜底
    
}

当然,这种大量的 if/else 判断,也会造成业务代码难以维护的情况存在, 大家可能更倾向使用 babel, postcss等工具进行转义。

我们即使不使用这个开源包, 其实可以从中学习到最简单的检测 某个环境是否支持 什么语法, 而不是一股脑的使用 垫片包, 增加项目体积

有的公司可能收集了用户的浏览器版本号,那更好,配合这个工具,可以做技术辅助和判断, 团队内部是否要使用交心语法写业务

看几个示例:

案例1:判断当前环境是否支持 箭头函数

Modernizr/feature-detects/es6/arrow.js at master · Modernizr/Modernizr (github.com)

js 复制代码
/*!
{
  "name": "ES6 Arrow Functions",
  "property": "arrow",
  "authors": ["Vincent Riemer"],
  "tags": ["es6"]
}
!*/
/* DOC
Check if browser implements ECMAScript 6 Arrow Functions per specification.
*/
define(['Modernizr'], function(Modernizr) {
  Modernizr.addTest('arrow', function() {
    try {
      // eslint-disable-next-line
      eval('()=>{}');
    } catch (e) {
      return false;
    }
    return true;
  });
});

案例2:判断 当前是否支持 ES6 中新增的 关于数组的语法

Modernizr/feature-detects/es6/array.js at master · Modernizr/Modernizr (github.com)

js 复制代码
/*!
{
  "name": "ES6 Array",
  "property": "es6array",
  "notes": [{
    "name": "ECMAScript 6 specification",
    "href": "https://www.ecma-international.org/ecma-262/6.0/index.html"
  }, {
    "name": "Last ECMAScript specification",
    "href": "https://www.ecma-international.org/ecma-262/index.html"
  }],
  "polyfills": ["es6shim"],
  "authors": ["Ron Waldon (@jokeyrhyme)"],
  "tags": ["es6"]
}
!*/
/* DOC
Check if browser implements ECMAScript 6 Array per specification.
*/
define(['Modernizr'], function(Modernizr) {
  Modernizr.addTest('es6array', !!(Array.prototype &&
    Array.prototype.copyWithin &&
    Array.prototype.fill &&
    Array.prototype.find &&
    Array.prototype.findIndex &&
    Array.prototype.keys &&
    Array.prototype.entries &&
    Array.prototype.values &&
    Array.from &&
    Array.of));
});

示例3: ES8 对象新增语法判断

js 复制代码
/*!
{
  "name": "ES8 Object",
  "property": "es8object",
  "notes": [{
    "name": "ECMAScript specification: Object.entries",
    "href": "https://www.ecma-international.org/ecma-262/#sec-object.entries"
  }, {
    "name": "ECMAScript specification: Object.values",
    "href": "https://www.ecma-international.org/ecma-262/#sec-object.values"
  }],
  "caniuse": "object-entries,object-values",
  "authors": ["dabretin"],
  "tags": ["es8"]
}
!*/
/* DOC
Check if browser implements ECMAScript 8 Object.
*/
define(['Modernizr'], function(Modernizr) {
  Modernizr.addTest('es8object', !!(Object.entries &&
    Object.values));
});

从上述几个案例看, 有的直接调用某个方法,如果不为 undefined, 或者不报错, 则支持。 大致思路是这样的, 当前库是参照了 ECMA的语法提案

相关推荐
我是伪码农4 分钟前
Vue 智慧商城项目
前端·javascript·vue.js
不认输的西瓜7 分钟前
fetch-event-source源码解读
前端·javascript
用户39051332192889 分钟前
前端性能杀手竟然不是JS?图片优化才是绝大多数人忽略的"降本增效"方案
前端
朱昆鹏1 小时前
开源 Claude Code + Codex + 面板 的未来vibecoding平台
前端·后端·github
lyrieek1 小时前
pgadmin的导出图实现,还在搞先美容后拍照再恢复?
前端
永远是我的最爱1 小时前
基于.NET的小小便利店前台收银系统
前端·sqlserver·.net·visual studio
从文处安1 小时前
「九九八十一难」第一难:前端数据mock指南(TS + VUE)
前端
Zhencode1 小时前
Vue3 响应式依赖收集与更新之effect
前端·vue.js
x-cmd1 小时前
[x-cmd] jsoup 1.22.1 版本发布,引入 re2j 引擎,让 HTML 解析更安全高效
前端·安全·html·x-cmd·jsoup
天下代码客2 小时前
使用electronc框架调用dll动态链接库流程和避坑
前端·javascript·vue.js·electron·node.js