Polyfill vs Shim:Core.js 如何让旧浏览器支持新语法? 大家好,欢迎来到今天的讲座。今天我们来深入探讨一个在现代前端开发中非常关键的话题:如何让旧浏览器支持新的 JavaScript 语法和 API? 你可能已经听说过“polyfill”或“shim”,但它们到底是什么?有什么区别?为什么我们不能直接用原生 ES6+ 的特性(比如 let、const、箭头函数、Promise、Array.from)在 IE11 或更低版本的浏览器里运行? 答案就藏在 core-js 这个强大的工具里。 一、什么是 Polyfill 和 Shim? 先从基础讲起。 ✅ Polyfill(填充器) Polyfill 是一种兼容性补丁代码,它通过模拟标准 API 来让旧环境支持新功能。 举个例子: 如果某个浏览器不支持 Array.from(),我们可以写一段代码去模拟它的行为。 这段代码会检查是否已有原生实现,如果没有,则注入自己的逻辑。 // 简化版 Array.from polyfill 示例 if (!Array.from) { Array.from = function(ar …