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

今天推荐一个开源的库, 它能够检测用户浏览器是否支持某些特性和功能, 不是通过 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的语法提案

相关推荐
z***75152 小时前
【Springboot3+vue3】从零到一搭建Springboot3+vue3前后端分离项目之后端环境搭建
android·前端·后端
fruge3 小时前
仿写优秀组件:还原 Element Plus 的 Dialog 弹窗核心逻辑
前端
an86950013 小时前
vue新建项目
前端·javascript·vue.js
w***95494 小时前
SQL美化器:sql-beautify安装与配置完全指南
android·前端·后端
顾安r5 小时前
11.22 脚本打包APP 排错指南
linux·服务器·开发语言·前端·flask
万邦科技Lafite5 小时前
1688图片搜索商品API接口(item_search_img)使用指南
java·前端·数据库·开放api·电商开放平台
yinuo6 小时前
网页也懂黑夜与白天:系统主题自动切换
前端
Coding_Doggy6 小时前
链盾shieldchain | 项目管理、DID操作、DID密钥更新消息定时提醒
java·服务器·前端
用户21411832636026 小时前
dify案例分享-国内首发!手把手教你用Dify调用Nano Banana2AI画图
前端
wa的一声哭了6 小时前
Webase部署Webase-Web在合约IDE页面一直转圈
linux·运维·服务器·前端·python·区块链·ssh