[译] 一文教你什么是渐进增强,为什么它很重要?

渐进增强(下文简称 PE)是一个在开发网页应用中十分有效的方法。

这里是正式定义:

渐进增强 使用Web技术以分层的方式,允许所有人访问网页的基本内容和功能,使用任何浏览器或互联网连接,同时还给更先进的浏览器软件或更大的带宽提供了这些页面的一个增强版本。— 维基百科

这个策略的优点是它允许所有人使用任何浏览器和网络连接能够访问到网页的基础内容和功能,也同时为使用高版本浏览器或者高带宽的用户提供一个增强版本的网页。

简而言之...

...它为我们提供了基本的用户体验,即使在兼容性不同的浏览器中也保证了网页的 稳定运行

let PE = "Progressive Enhancement";
复制代码

渐进增强策略由以下几个 核心原则组成:

  • 基本的 网页内容 应该能被 所有的浏览器访问
  • 基本的 网页功能 应该能在 所有的浏览器中运行
  • 有限的语义标记包含所有内容
  • 增强的网页布局由外部引用的 css 提供
  • 增强的网页行为由外部引用的 JavaScript 提供
  • 尊重用户使用的浏览器首选项

所以当你使用下一代只在 合适的环境 下正常工作的 JavaScript/CSS 框架构建你的最新网站时,如果这些代码离开了特定环境就无法运行,便不符合渐进增强的策略。

相反,在引入更复杂的代码前,我们的开发目标应该是从提供基本功能、稳定的设备兼容性、和无卡顿的体验开始。

渐进增强案例

让我们一起来看看一些渐进增强策略的案例是如何运行的。

网页字体

网页字体固然漂亮,但是当用户网络环境较差时,加载它们会降低用户体验。在这种情况下,可以使用系统字体渲染网页内容,当环境改变需要加载网页字体时,也可以顺利切换过去。

有内容总比等待加载网页字体或什么也不显示要好得多。

初始 HTML

网页负责加载脚本,例如 Angular、React 或其他框架。当这些脚本负责网页初始内容渲染时,在低速网络下或者脚本发生错误你的用户会在浏览器或设备中看到空白页面。

想一想,初始加载使用 HTML 渲染总是会比完全依赖脚本来渲染页面有更好的用户体验,而不是等待脚本加载完成。

功能检查

好的网站总是会做这个部分,当使用一个可能不会被其他设备、浏览器支持的功能时,总是在 JavaScript 中使用它前确保该功能是在指定浏览器中可用的。

Modernizr 是一个受欢迎的功能检测库,也许能帮到你。

只在不支持你需要的功能的浏览器或设备中引入额外脚本,避免在支持这些功能的浏览器中引入额外脚本。

现在,为何选择渐进增强?

在构建下一个应用程序之前关注渐进增强策略的重要原因:

坚实的基础

渐进增强的重点在于,当你处于项目初期,在引入任何复杂的功能前你只使用最基本的 web 技术。这样在任何的情况下你都有支持保证更复杂功能运行的基础。

一旦团队对网站的核心体验已经很有自信,并且在不依赖网速、浏览器、设备时也能运行,这时你就可以开始引入更加复杂的功能和布局。

稳定性

测试团队:“ 搜索图标在Safari的offres页面失效 ”

开发团队:“ 在我的电脑上可以啊,清缓存再试一下,不行就没办法了”

测试团队(来自天堂):“ 还是不行,你是在 Chrome 上看的吧,Safari 上是不行的”

开发团队:“ 我们什么时候开始兼容 Safari了?等等... 修复中...”

if(getBrowsers() == 'safari') {
Patch.magicHelpers.searchIconMagic()
}

Patch.magicHelpers = {
searchIconMagic: function() {
// Can't share magic, doing something
   }
};
复制代码

“一个小时后…… 再检查一下看看”

测试团队: “ 在 Chrome 和 Safari 中可以了,但是 Mozilla FireFox 中又不行了... 啊啊啊!”

承认吧,我们都至少经历过这种情况不止一次吧。

项目的稳定性和维护成本也取决于项目是如何开始的。使用框架来配置项目并在后面不停修复可能不是长久之计。

渐进增强策略可以帮你构建一个更有健壮基础的项目,你的 HTML、CSS 和 JS 都是可以支持回退的。他们可以保证你不会严重的依赖浏览器的特定功能。

SEO 和可访问性

每个人都希望自己的应用被列在搜索引擎列表的第一页,但这需要我们提供不懈的努力和计划来构建如此优秀的应用。而你项目中的健壮基础保证了你的应用专注于内容优先。

使用渐进增强策略的网页可以保证 基础内容 能够 总是 被搜索引擎的爬虫爬取到并添加到索引。避免任何可能阻碍爬虫抓取网页内容的动态加载。

无论用户的浏览器设置是什么,渐进式 WEB(PWA)应用总是可以满足他们。因为应用是使用渐进增强原则构建的。

总结思考

渐进增强策略专注于为你的项目提供健壮的基础,这个基础可以为你在产品长期的计划中提供巨大帮助。

在你的新项目中使用新的 JavaScript/CSS 框架可能是很容易的,但是那可能会让你去优雅降级。你会不断的修复你的代码以支持那些不支持框架的浏览器和设备。

尽管渐进增强策略也许在项目开始阶段会占用你更多的一点时间,但是它可以保证在最坏的情况下也可以提供最基本的功能。在严重依赖 JavaScript 实现用户界面展示的情况下可能不适用渐进增强策略,但是对于一个长期的项目,渐进增强是值得考虑的。

希望这篇文章能为你提供一些对渐进增强的概略的了解。

更多的关于渐进增强的文章:

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏

猜你喜欢

转载自juejin.im/post/5c2f42556fb9a049f57148ca