写点什么

为什么 Safari 浏览器这么不受 Web 开发者待见?

  • 2021-10-25
  • 本文字数:2882 字

    阅读完需:约 9 分钟

为什么Safari浏览器这么不受Web开发者待见?

时至今日,IE 6 的种种遗留问题仍然困扰着不少 Web 开发人员。这款虽然经典但却毛病多多的浏览器大大降低了开发者的生活质量,甚至有激进的观点认为它几乎毁掉了整个互联网。总之,IE 真的很差劲,它相当于是逼着 Web 开发者在冰天雪地中爬坡前行……经历过的估计都懂。


但就算没经历过那个时代,如今的 Web API 开发人员也面临着类似的难题——只不过这一次,难题来自苹果。


苹果的 Safari 浏览器在支持 Web 功能方面远远落后于其他竞争对手,这种落后到底达没达到当初 IE 的“高度”仍有争议,但不少人已经把 Safari 视为 IE“精神”留下的现实映射。而且可以肯定的是,Safari 当中的 WebKit 引擎确实远不及其他浏览器方案。根据Web Platform Tests公布的仪表板,基于 Chrome 的浏览器能够支持 94%的测试套件、Firefox 支持 91%,而 Safari 仅支持 71%。在桌面端,问题似乎不大;毕竟用户可以随时切换到最经典的谷歌 Chrome(甚至 Vivaldi)。


但是,在 iOS 设备上,情况就没那么简单了。

iOS 对于浏览器的垄断

根据苹果 App Store 中发布的规定,“用于浏览网页的应用必须使用适当的 WebKit 框架与 WebKit JavaScript。”换句话说,无论选择 Safari 还是 Chrome,iPhone 用户们实际上使用的都是 Safari/WebKit 这对弱智组合。


苹果在 iOS 上垄断了浏览器选择权,这是微软在 IE 身上永远没能实现的终极目标。在 Windows 中,用户至少还可以安装 Firefox。但即使在 iOS 上使用其他浏览器、包括 Firefox,我们用到的在本质上也仍然是 WebKit。或者说,只要大家选择了 iOS 设备,那么 Safari 就将永远伴你左右。


而真正让 Web 开发者们头疼的,则是苹果缓慢的开发周期。苹果最快也要每六个月左右才更新一次 Safari。而基于 Blink 的 Chrome 系浏览器则每六周更新一次(很快将进一步缩短为每四周更新),Firefox 每四周更新一次,Brave 甚至每三周就迎来一波更新。如此一来,苹果不仅是添加新功能的速度太慢,这样的开发周期也让简单的 bug 修复成果得等上好久才能正式登陆用户设备,而某些受到 Safari bug 影响的网站可能需要等待一年才能解决问题。


再深入观察,我们会发现 Web Platform Tests 数据还暴露出 Safari 的另一大短板——即使 WebKit 能够实现某项功能,其效果也往往不够完整。以渐进式 Web 应用程序(PWA)为例,其目标是希望能让 Web 应用的使用体验无限接近于原生移动应用。


用于构建 PWA 的相关 API 可以实现全屏运行(无浏览器 UI)、发送通知与警报、离线状态运行以及通过主屏幕图标启动等等。目前最具知名度的 PWA 案例当数 Twitter 与 Uber。


苹果已经为开发人员实现了构建 PWA 所需要的大部分功能,但其中仍有着不少局限性。比如苹果还没添加对发送通知和主屏幕应用图标的支持,因此本质上可以说 Safari 还没有实现某些真正能让网站用起来像原生应用的核心功能。


也正是因为苹果这种故意削弱 WebKit 来护着自家 App Store 业务的行为,引发了开发领域的激烈争论。因为如果苹果老老实实推出所有支持功能,开发者就能构建起更好的 Web 应用,那到时候没人买原生应用了怎么办……苹果在 iOS App Store 中可是拥有 30%的佣金抽成。


热衷于做 Web 应用的开发者们对上述问题自然是非常关心的,但苹果则不然——他们是世界上财力最雄厚的企业之一,并不担心自己的倒行逆施行为会惹恼 Web 开发者群体。更重要的是,苹果在保护自身利益的同时,还把新 API 支持功能的缺失解释成保护用户隐私……打着这面大旗,其他人也确实不好多说什么。

Safari 真的在拯救 Web 吗?

Safari 的支持者以及苹果本身都坚定认为,之所以不支持那些新型 API,是为了避免开发者访问用户的 USB 端口、蓝牙装置、电池状态及 NFC 传感器等,进而导致广告商利用这些信息不断侵蚀本已很脆弱的互联网隐私。就算不担心隐私,这些 API 也会减弱手机的电池续航能力。


我本人并不是 iOS 用户,但苹果在隐私问题上的坚定立场确实让我相当心动。


我承认,我非常讨厌现代网络,但我对隐私问题也不太担心,毕竟使用移动设备本身就代表着与隐私的背离。我重视隐私,但如今网站可靠性低、速度慢而且对用户抱有敌意等整体趋势已经让这种重视毫无意义。


我非常不喜欢 JavaScript 驱动的 Web API 所带来的体验,所以已经开始在浏览过程中禁用 JavaScript,这样网络能瞬间恢复最初漂亮、简洁的状态,而苹果肯定特别欣赏我这样的用户。我用过很多无需 JavaScript 即可加载的网站,而且坚决不碰那些强制要求使用 JavaScript 的站点。没错,既然 Invidious(YouTube 的开源前端替代产品)都能在无需 JavaScript 的前提下加载 YouTube 内容,为什么 YouTube 自己不行?我不在乎具体理由,但写了个脚本保证自己总会被重新定向至 Invidious 或者 PeerTube。


我想说的是,在这个问题上我是支持苹果的;但我也承认,苹果这种 Safari 落后性源自保护用户隐私的说法压根站不住脚。虽然我觉得苹果不会非常担心 Web 开发者能损害到 App Store 的根本利益,但其中的种种负面可能性也确实不得不防。于是,苹果出于利益做出了选择,再把它强行解释成是在保护用户隐私。


这些新 API 正在快速入驻其他浏览器,所以在一段时间之后,微软 IE 当初的惨剧估计会重新上演。而大家也都清楚故事的结局:微软输了,其他浏览器都在快速发展,只有微软 IE 彻底无人问津。


如果苹果也沿着这条路走下去,那他们不仅会输、甚至可能拖着整个 Web 一起陷落。因为苹果支持者们有一点是对的:如果苹果愿意接受谷歌 Blink 的主宰,那其他竞争厂商也只能服从。


那这位新“主宰者”的能力究竟如何?Web 开发者 Tim Perry 最近写了一篇名为《Safari 不是在保护 Web, 而是正杀死它》的文章,他表示,过去每种浏览器都会提供自己的扩展 API。但如今,“Chrome 已经深入人心,他们不断提供更强大、更易于使用的扩展 API,人气也一路水涨船高。而 Firefox 与 Safari,它们放弃了自有 API,转而接纳 Chrome 的 API。这相当于允许谷歌凭一己之力塑造 Web 扩展标准。”是的,当没人敢站出来对抗市场领导者时,就会发生这种情况。“如果情况没有大的变动,那么谷歌的主宰之势将愈演愈烈。这绝不是什么好消息。”

写在最后

必须有人站出来阻挡谷歌和 Blink 疯狂的扩张脚步,确保不断涌现的 API 真能给 Web 用户带来助益。这一点对苹果用户很重要,对谷歌用户乃至 Web 开发者也同样重要。


大部分现代 Web 功能的开发是悄然进行的,期间鲜有争论。Blink 开发者会在 Chrome 当中以开发者标记的形式发布这些新功能。这已经成为一种共识和习惯,再要辩论或调整恐怕已经非常困难。


我倒不是说苹果的动机就真有多高尚,但他们对 Safari 的坚持至少还能逼迫谷歌在统一 Web 标准流程的霸业上放缓脚步……但苹果方面也得做出改变,否则 Safari 有可能步 IE 的后尘。


我的这些想法可能太过理想,但正如 Web 倡导者(前 Opera 布道师)Bruce Lawson所言,“如果苹果允许 Safari 真正参与竞争,对于 Web 开发者、企业、消费者乃至整个 Web 领域的健康状况都将是个好消息。”


如果苹果能够调整功能开发当中的透明度(减少)与加快响应速度,那它一定可以更多地在新 API 的发展中发挥作用。而且如果苹果真的担心 API 影响到用户隐私,就该用行动捍卫自己的观点、反击谷歌、拿出一套有竞争力的 Chrome 替代品。这可能不容易,但却是今后 Web 还能健康发展的唯一希望。


原文链接:

https://www.theregister.com/2021/10/22/safari_risks_becoming_the_new_ie/

2021-10-25 15:0614626

评论 1 条评论

发布
用户头像
很同意Safari在浏览器的开发上给予Google的Chrome以阻拦,但更新确实要快一些啊,不能这么拖沓。很多W3C的标准,要给Chrome压力,这样才能有话语权,有竞争力。维持现状只能走Microsoft的老路。
2021-11-02 14:25
回复
没有更多了
发现更多内容

CAD图纸如何批量转换成PDF格式?

在路上

cad

抖音商品详情API秘籍!轻松获取商品详情数据

tbapi

抖音商品数据采集 抖音API 抖音商品详情接口 抖音商品详情API 抖音商品数据分析

“全”事件触发:阿里云函数计算与事件总线产品完成全面深度集成

Apache RocketMQ

云原生 消息队列 EventBridge

RocketMQ在搜狐的创新实践

Apache RocketMQ

kafka RocketMQ 云原生 消息队列

YashanDB集群维护与升级实操指南

数据库砖家

YashanDB架构设计与实现,助力企业数字化转型

数据库砖家

研发交付的“定心丸”:嘉为蓝鲸CFlow价值流管理平台以稳定替代数量,筑牢业务信任

嘉为蓝鲸

DevOps 研发效能 价值流 价值流管理平台

TRAE cue 背后的挑战与思考

火山引擎开发者社区

火山引擎 大数据 火山引擎 云服务 Trae

EDA 事件驱动架构与 EventBridge 二三事

Apache RocketMQ

阿里云 Serverless 云原生 消息队列 事件总线

YashanDB集群管理及容灾备份实用教程

数据库砖家

海外舆情监测数据的商业价值挖掘:从信息到决策

沃观Wovision

数据分析 舆情监测系统

跟着“苏超”畅游金陵城,打卡江苏电信5GA

极客天地

聚焦日志查询体验!嘉为蓝鲸WeOps V5.25&V4.25用AI破解查询难题

嘉为蓝鲸

智能运维 一体化运维 一体化智能运维平台

DWG格式CAD文件如何转成DXF格式?

在路上

cad cad看图 CAD看图软件 CAD看图王

恶疟原虫目标检测数据集(2700张图片已划分、已标注)【数据集分享】

申公豹

数据集

基于消息队列 RocketMQ 的大型分布式应用上云最佳实践

Apache RocketMQ

阿里云 RocketMQ 云原生 消息队列

基于 RocketMQ 的基金数字化陪伴体系的架构实践

Apache RocketMQ

阿里云 RocketMQ 云原生 消息队列 金融行业

化“不可抗力”为“可控影响”:AI时代的项目效能革新

思码逸研发效能

研发效能 效能度量 研发效能管理 思码逸

再赴香港!嘉为蓝鲸亮相网络安全技术研讨会,与伙伴共探行业发展新趋势

嘉为蓝鲸

DevOps AIOPS 智能运维 研发运维 研运一体化

YashanDB监控报警系统设计与实现技巧

数据库砖家

语音模型初创「宇生月伴」获数千万元融资;游戏 AI 陪伴逗逗发布 1.0 版,引入 RTC 实时通讯丨日报

RTE开发者社区

嘉为蓝鲸CMeas研发效能管理平台:数据下钻技术如何让问题根因“无处遁形”

嘉为蓝鲸

DevOps 研发效能 研发效能度量 研发效能洞察管理

解码监控可视化:IT运维如何通过图形化语言实现从数据到决策的高效转化?

嘉为蓝鲸

数据库监控 智能监控 IT运维 IT监控 IT运维监控

RocketMQ 千锤百炼--哈啰在分布式消息治理和微服务治理中的实践

Apache RocketMQ

阿里云 云原生 MQ 消息队列

阿里云 EventBridge 事件驱动架构实践

Apache RocketMQ

云原生 消息队列 EventBridge

TRAE cue 迎来月度最大更新,模型能力以及时延大幅优化

火山引擎开发者社区

Trae

开口就行!TRAE 2.0 语音输入功能

火山引擎开发者社区

AI 火山引擎 Trae

博时基金基于 RocketMQ 的互联网开放平台 Matrix 架构实践

Apache RocketMQ

阿里云 云原生 MQ 消息队列 Matrix

Chrome停用Manifest V2?一招教你无缝迁移插件到洋葱头浏览器

贝锐

chrome 浏览器 Chrome插件

阿里云消息队列 RocketMQ 5.0 全新升级:消息、事件、流融合处理平台

Apache RocketMQ

阿里云 RocketMQ 云原生 消息队列

为什么Safari浏览器这么不受Web开发者待见?_大前端_Scott Gilbertson_InfoQ精选文章