What is a Polyfill?[翻译]

Polyfill是为了解决浏览器对新API的支持不足而创建的,它使用JavaScript或其他技术来模拟未来API的行为,提供向后兼容性。这个词由作者在2009年提出,旨在填补浏览器功能的空白,类似墙面修补的膏状物。它不是渐进式增强或优雅降级,而是一个独立的概念,确保代码在缺乏原生功能的环境中也能正常工作。
摘要由CSDN通过智能技术生成

原文地址:What is a Polyfill

polyfill这个词是怎么来的

那是我写作的时候HTML5引入早在2009年。我坐在咖啡店里(和你一样),想着我想要一个词,意思是
“如果浏览器没有原生的API,用JavaScript(或Flash或其他什么)复制API”。
对我来说,Shim意味着一段代码,你可以添加它来修复一些功能,但它通常有自己的API。我想要的是一些你可以投入并且可以默默地工作的东西(还记得以前的shim.gif吗?这需要你实际插入图像来修复空td单元格-我想要的东西,为我自动)。
我知道我所追求的不是渐进式增强,因为我所追求的基线需要JavaScript和最新的技术。所以现有的术语对我不适用。
我还知道这不是优雅的降级,因为没有本机功能和JavaScript(假设您的polyfill使用JavaScript),它根本无法工作。
所以我想要一个简单的词,能让人对这个东西的功能有一个模糊的概念。我是突然想到了Polyfill,但它符合我的要求。Poly意味着它可以使用任何数量的技术来解决——它不仅仅局限于使用JavaScript,而fill将填补浏览器中需要技术的漏洞。它也不意味着“旧浏览器”(因为我们也需要填充新浏览器)。
对我来说,我的产品Polyfilla(美国称为spackling)是一种可以贴在墙上的膏状物,可以覆盖裂缝和洞。我真的很喜欢这个可视化我们如何修复浏览器的想法。一旦墙壁是平的,你可以随心所欲地油漆或墙纸。
我有一些反馈说“这个词应该改”,但更多的是当时的社区需要一个词,就像我们需要Ajax、HTML5、Web 2.0一样,这些东西可以挂起我们的想法。不管这个词是否完美契合,事实证明它是有腿的,开发人员和设计师都理解这个概念。
我故意没有真正把这个术语放在那里,我只是把它放在了一些关键的地方(最明显的是在书中),我想当Paul Irish在几个月后的一次演讲中直接引用了术语polyfill时,这个术语才真正得到了大量的曝光(我想这也有助于添加Modernizr HTML5 shims & polyfill页面)。

定义

亚历克斯·塞克斯顿也将多填充分类为一种递减增强形式。我认为这很好地总结了这一点。
保罗也定义为:
一个模拟未来API的垫片,为旧浏览器提供回退功能。

一些例子

这里有一个例子:sessionStorage在所有最新的浏览器(IE8及以上版本)中都可用,但在IE7及以下版本中没有。
可用于填充插上支架用于不提供sessionStorage的旧浏览器。
现在有了polyfiller,作为开发人员,我可以依赖于使用Web Storage API(用于会话),而不必在我的代码或分支中进行特性测试来处理不同的情况。
另一个例子是在IE中提供画布支持。这就是聚的部分。如果没有原生画布,我们可以提供使用Silverlight支持画布。如果Silverlight不可用,我们可以使用VML usingexcanvas(注意,excanvas实际上也包括一个Silverlight桥,我希望它会首先尝试)。使用这两个脚本为开发人员提供了一个(相当)可靠的画布备份,如果它在浏览器中不是本地的。

它从哪里来,要去哪里

今年早些时候,我参与撰写了HTML5引入布鲁斯·劳森。在研发期间,我一直在寻找填补缺失api的垫片和技术,但它们并不是非常渐进的增强。我想要一个简单的词来代表这个想法,即有一个“东西”可以堵塞浏览器,但不是渐进式增强,也不是优雅的降级。
Polyfilling似乎符合我想说的(在我的脑海里!)
Ployfilla是一种英国产品,在美国被称为Spackling Paste。记住这一点:把浏览器想象成一堵有裂缝的墙。这些填充物有助于消除裂缝,为我们提供了一堵平滑的浏览器墙。
我试探性地用了这个新词HTML5说话为ThinkVitamin早在6月,但我不想推行它,因为担心过于努力推出一个新术语。然而,我确实把它偷偷地放在了HTML5介绍中,我只能假设这导致了最近发生的事情。
最近在JS相依,保罗爱尔兰发布了一个填料和垫片清单-一个很棒的资源列表,让我们开发人员免受旧浏览器的痛苦。
看起来polyfilling有一些腿,所以让我们开始使用它们,并将旧的(甚至更新的)浏览器拖到我们的期望。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值