头图

JavaScript中的Polyfill到底是什么鬼?

前言

大家好,我是倔强青铜三。是一名热情的软件工程师,我热衷于分享和传播IT技术,致力于通过我的知识和技能推动技术交流与创新,欢迎关注我,微信公众号:倔强青铜三

你好,JavaScript爱好者们!👋 是否曾遇到浏览器不兼容的尴尬时刻?😤 你在使用一个闪亮的现代特性,但一些用户仍然坚持使用旧版浏览器,仿佛它们是珍贵的古董。这时你的救星Polyfills登场!

什么是Polyfill?🤔

将Polyfill想象成一个小助手,它为旧环境添加现代特性。就像把智能手机带到中世纪战场——过时的浏览器突然学会了新技巧。🧙‍♂️

让我们动手实践!🛠️

问题:旧浏览器不支持Array.prototype.includes

现代JavaScript代码:

const fruits = ["apple", "banana", "mango"];
console.log(fruits.includes("banana")); // true

但等等!旧浏览器惊呼:“什么是.includes?” 😱

让我们用Polyfill来修复它!

Polyfill魔法

if (!Array.prototype.includes) {
  Array.prototype.includes = function (item) {
    return this.indexOf(item) !== -1;
  };
}

现在,即使是IE浏览器也能像专业人士一样理解.includes。🎉

另一个例子:Object.assign

现代JavaScript代码:

const target = { a: 1 };
const source = { b: 2 };
const result = Object.assign(target, source);
console.log(result); // { a: 1, b: 2 }

但旧浏览器呢?《“没听说过。”》 🤷‍♂️

这是我们如何帮助它们的:

if (typeof Object.assign !== "function") {
  Object.assign = function (target, ...sources) {
    if (target == null) {
      throw new TypeError("Cannot convert undefined or null to object");
    }
    const to = Object(target);
    sources.forEach(source => {
      if (source != null) {
        for (const key in source) {
          if (Object.prototype.hasOwnProperty.call(source, key)) {
            to[key] = source[key];
          }
        }
      }
    });
    return to;
  };
}

瞧!🥳 你刚刚教会了古老浏览器如何使用Object.assign

但是…你应该总是使用Polyfills吗?🛑

别急,英雄!虽然Polyfills很强大,但它们会增加你的捆绑包大小。策略性地使用它们,或者利用像core-js这样的库来管理Polyfills。更好的是,使用Babel进行自动转换。🌟

挑战时间:你能破解这个吗?🧠

这是一个棘手的问题:这个Polyfill是做什么的?🤔

if (!String.prototype.padStart) {
  String.prototype.padStart = function (targetLength, padString) {
    targetLength = targetLength >> 0; // 如果是数字则截断
    padString = String(padString || " ");
    if (this.length > targetLength) {
      return String(this);
    } else {
      targetLength = targetLength - this.length;
      if (targetLength > padString.length) {
        padString += padString.repeat(targetLength / padString.length);
      }
      return padString.slice(0, targetLength) + String(this);
    }
  };
}

提示: 它与字符串有关…但它是做什么的?在评论中留下你的猜测!📝

总结

Polyfills就像JavaScript的胶带——快速修复浏览器的漏洞。无论你是自己编写Polyfill还是使用库,它们都是实现向后兼容性的不可或缺的工具。


倔强青铜三
28 声望0 粉丝