1
0
wiki/Technology/WebDevelopment/1.Browser/3.Firefox.html

452 lines
552 KiB
HTML
Raw Permalink Normal View History

2024-10-10 16:56:32 +08:00
<!DOCTYPE html>
<html lang="zh"><head><title>Firefox</title><meta charset="utf-8"/><link rel="preconnect" href="https://fonts.googleapis.com"/><link rel="preconnect" href="https://fonts.gstatic.com"/><link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=IBM Plex Mono&amp;family=Noto Serif Simplified Chinese:wght@400;700&amp;family=Source Sans Pro:ital,wght@0,400;0,600;1,400;1,600&amp;display=swap"/><meta name="viewport" content="width=device-width, initial-scale=1.0"/><meta property="og:title" content="Firefox"/><meta property="og:description" content="Mozilla Firefox 是一款开源网络浏览器,由 Mozilla 基金会开发以隐私保护和开源社区支持而闻名。自2004年发布以来它提供了高速浏览体验并通过诸如Gecko渲染引擎、SpiderMonkey JavaScript引擎、以及Quantum项目等技术创新不断优化性能。Firefox 支持跨平台使用,提供扩展兼容性,并注重用户隐私与安全。 ..."/><meta property="og:image" content="https://wiki.7wate.com/static/og-image.png"/><meta property="og:width" content="1200"/><meta property="og:height" content="675"/><link rel="icon" href="../../../static/icon.png"/><meta name="description" content="Mozilla Firefox 是一款开源网络浏览器,由 Mozilla 基金会开发以隐私保护和开源社区支持而闻名。自2004年发布以来它提供了高速浏览体验并通过诸如Gecko渲染引擎、SpiderMonkey JavaScript引擎、以及Quantum项目等技术创新不断优化性能。Firefox 支持跨平台使用,提供扩展兼容性,并注重用户隐私与安全。 ..."/><meta name="generator" content="Quartz"/><link href="../../../index.css" rel="stylesheet" type="text/css" spa-preserve/><link href="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.9/katex.min.css" rel="stylesheet" type="text/css" spa-preserve/><script src="../../../prescript.js" type="application/javascript" spa-preserve></script><script type="application/javascript" spa-preserve>const fetchData = fetch("../../../static/contentIndex.json").then(data => data.json())</script></head><body data-slug="Technology/WebDevelopment/1.Browser/3.Firefox"><div id="quartz-root" class="page"><div id="quartz-body"><div class="left sidebar"><h2 class="page-title"><a href="../../..">🪴 X·Eden</a></h2><div class="spacer mobile-only"></div><div class="search"><button class="search-button" id="search-button"><p>搜索</p><svg role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19.9 19.7"><title>Search</title><g class="search-path" fill="none"><path stroke-linecap="square" d="M18.5 18.3l-5.4-5.4"></path><circle cx="8" cy="8" r="7"></circle></g></svg></button><div id="search-container"><div id="search-space"><input autocomplete="off" id="search-bar" name="search" type="text" aria-label="搜索些什么" placeholder="搜索些什么"/><div id="search-layout" data-preview="true"></div></div></div></div><button class="darkmode" id="darkmode"><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="dayIcon" x="0px" y="0px" viewBox="0 0 35 35" style="enable-background:new 0 0 35 35" xml:space="preserve" aria-label="暗色模式"><title>暗色模式</title><path d="M6,17.5C6,16.672,5.328,16,4.5,16h-3C0.672,16,0,16.672,0,17.5 S0.672,19,1.5,19h3C5.328,19,6,18.328,6,17.5z M7.5,26c-0.414,0-0.789,0.168-1.061,0.439l-2,2C4.168,28.711,4,29.086,4,29.5 C4,30.328,4.671,31,5.5,31c0.414,0,0.789-0.168,1.06-0.44l2-2C8.832,28.289,9,27.914,9,27.5C9,26.672,8.329,26,7.5,26z M17.5,6 C18.329,6,19,5.328,19,4.5v-3C19,0.672,18.329,0,17.5,0S16,0.672,16,1.5v3C16,5.328,16.671,6,17.5,6z M27.5,9 c0.414,0,0.789-0.168,1.06-0.439l2-2C30.832,6.289,31,5.914,31,5.5C31,4.672,30.329,4,29.5,4c-0.414,0-0.789,0.168-1.061,0.44 l-2,2C26.168,6.711,26,7.086,26,7.5C26,8.328,26.671,9,27.5,9z M6.439,8.561C6.711,8.832,7.086,9,7.5,9C8.328,9,9,8.328,9,7.5 c0-0.414-0.168-0.789-0.439-1.061l-2-2C6.289,4.168,5.914,4,5.5,4C4.672,4,4,4.672,4,5.5c0,0.414,0.168,0.789,0.439,1.06 L6.439,8.561z M33.5,16h-3c-0.828,0-1.5,0.672-1.5,1.5s0.672,1.5,1.5,1.5h
<h3 id="firefox-的概述与特点">Firefox 的概述与特点<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的概述与特点" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="诞生背景">诞生背景<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#诞生背景" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Firefox 是由 Mozilla 基金会发布的开源浏览器,其历史可以追溯到 2002 年以“Phoenix”项目为起点。</strong> 作为 Netscape 浏览器的继承者Firefox 的目标是提供一个<strong>开放源代码、隐私保护至上</strong>的浏览器推动开放互联网的发展。2004 年Firefox 正式推出 1.0 版本,并迅速成为主流浏览器,打破了当时 Internet Explorer 的垄断地位。</p>
<h4 id="核心特性">核心特性<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#核心特性" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li><strong>速度</strong>Firefox 使用的<strong>Gecko 渲染引擎</strong><strong>SpiderMonkey JavaScript 引擎</strong>对页面加载和执行速度进行了持续优化。通过引入<strong>Quantum 项目</strong>Firefox 的性能在 2017 年得到了显著提升特别是在多核处理器上的并发执行效率方面。Quantum 通过改进 Gecko 引擎的架构,使得浏览器在处理复杂网页时的速度和响应能力大幅提高。</li>
<li><strong>隐私与安全</strong>Firefox 以其<strong>强大的隐私保护功能</strong>著称。浏览器内置了<strong>增强型追踪保护</strong>,可以阻止广告追踪器、第三方 Cookie 以及恶意脚本的运行。此外Firefox 还提供了<strong>隐私浏览模式</strong>自动清除会话结束后的所有历史记录和数据。Mozilla 还在持续开发工具,如<strong>Firefox Monitor</strong>,帮助用户检测数据泄露,进一步保障用户隐私。</li>
<li><strong>扩展支持</strong>Firefox 支持广泛的扩展生态系统,并且与 Chrome 的扩展框架兼容,采用了<strong>WebExtensions API</strong>。这意味着大多数为 Chrome 开发的扩展可以轻松移植到 Firefox用户可以访问大量扩展程序来定制浏览器功能。</li>
<li><strong>开源与透明</strong>作为一个开源项目Firefox 的源代码对公众开放任何开发者都可以查看、贡献或修改其代码。Mozilla 通过社区驱动的开发模式确保了浏览器的透明性和公正性。Firefox 的开放性不仅为开发者提供了自由,也使得用户能够信任该平台不会滥用数据或隐私。</li>
<li><strong>跨平台支持</strong>Firefox 支持多种操作系统,包括<strong>Windows</strong><strong>macOS</strong><strong>Linux</strong><strong>Android</strong><strong>iOS</strong>。无论在哪个平台上Firefox 都提供一致的用户体验和功能集成,确保用户在不同设备上能够无缝切换浏览体验。</li>
<li><strong>同步功能</strong>Firefox 提供<strong>同步功能</strong>,允许用户通过创建 Firefox 账户,同步书签、浏览历史、扩展、密码和设置等信息。这一功能对于在多个设备上使用 Firefox 的用户而言,极大地提升了便利性和一致性。</li>
</ul>
<h4 id="市场份额">市场份额<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#市场份额" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>尽管 Firefox 的市场份额较谷歌 Chrome 有所减少,但它在隐私保护、开发者工具以及开源社区中的影响力依然显著。</strong> 尤其是在注重隐私和安全的用户群体以及开发者社区中Firefox 继续保持较高的忠诚度。开发者工具(如<strong>Firefox DevTools</strong>)提供了与 Chrome DevTools 类似的功能,吸引了大量开发者使用 Firefox 作为调试和开发环境。</p>
<h3 id="firefox-与-mozilla-的关系">Firefox 与 Mozilla 的关系<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-与-mozilla-的关系" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="mozilla-基金会">Mozilla 基金会<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#mozilla-基金会" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Mozilla 基金会</strong>是非营利组织,成立于 2003 年,负责 Firefox 浏览器的开发与维护。Mozilla 的使命是促进开放、可访问、隐私保护的互联网发展。与一些商业浏览器不同Mozilla 的非营利性质确保了其不会依赖广告和数据追踪来获利,从而进一步保障了用户的隐私和数据安全。</p>
<h4 id="gecko-引擎">Gecko 引擎<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#gecko-引擎" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Gecko</strong>是 Mozilla 独立开发的渲染引擎,与 Chrome 的 Blink 引擎不同。Gecko 是开源的,旨在符合 W3C 的最新 Web 标准,并且经过了持续的优化,以提高性能、兼容性和安全性。它为 Firefox 提供了强大的 Web 渲染能力,并支持复杂的网页布局和动画处理。</p>
<h4 id="quantum-项目">Quantum 项目<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#quantum-项目" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Quantum 项目</strong>是 Mozilla 于 2017 年启动的重大性能提升计划,旨在彻底重构 Firefox 的引擎架构使其更快、更高效。Quantum 通过并行处理、多线程任务调度和内存管理的优化,使得 Firefox 在多核处理器上可以更好地利用硬件资源。这一项目极大提升了 Firefox 的加载速度、响应性和稳定性,并缩小了与其他主流浏览器的性能差距。</p>
<p>Quantum 项目的推出标志着 Firefox 进入了一个新的性能时代,使其在与 Chrome 的竞争中具有了更强的技术基础。</p>
<h2 id="firefox-历史发展">Firefox 历史发展<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-历史发展" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<h3 id="firefox-的早期发展2002-2010">Firefox 的早期发展2002-2010<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的早期发展2002-2010" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="phoenix-和-firebird">Phoenix 和 Firebird<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#phoenix-和-firebird" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 的历史可以追溯到 2002 年,当时 Mozilla 社区开发了一个名为<strong>Phoenix</strong>的浏览器,作为 Netscape Navigator 的继承者。Phoenix 以其轻量、快速和灵活的特性,试图与当时市场主导的 Internet Explorer 竞争。由于与另一个软件发生商标冲突Phoenix 被改名为<strong>Firebird</strong>。但很快Mozilla 决定将其最终命名为<strong>Firefox</strong></p>
<p>2004 年Mozilla 发布了<strong>Firefox 1.0</strong>这是第一个正式版本。它以简洁的界面和卓越的性能迅速吸引了用户。当时Firefox 作为开源的替代选择提供了更强的安全性、隐私保护和浏览体验受到广大用户的欢迎。2004 年底Firefox 的下载量突破了 100 万次,标志着其作为主流浏览器的崛起。</p>
<h4 id="mozilla-的开放源代码理念">Mozilla 的开放源代码理念<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#mozilla-的开放源代码理念" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 的诞生与发展深受<strong>Mozilla 开放源代码理念</strong>的影响。作为一个完全开源的浏览器Firefox 的代码对全球开发者开放,任何人都可以为其做出贡献。这种开发模式使得 Firefox 能够快速响应用户需求,进行持续的改进与创新。</p>
<p>开源社区的支持不仅推动了 Firefox 技术的进步,还帮助其打造了一个高度活跃的开发者生态系统。这一生态系统为 Firefox 带来了新的功能和修复,也使得它能够快速跟进和实施最新的 Web 标准。</p>
<h4 id="firefox-扩展生态的建立">Firefox 扩展生态的建立<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-扩展生态的建立" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 在早期就意识到了<strong>扩展支持</strong>的重要性。它为用户提供了高度可定制的浏览体验,允许开发者创建扩展来增强浏览器的功能。通过 Firefox 扩展生态,用户可以安装广告拦截器、开发者工具、密码管理器等各种插件,满足不同的使用需求。</p>
<p>Firefox 的扩展系统帮助它迅速积累了大批忠实用户和开发者。Firefox 成为了第一款主流浏览器中提供强大扩展支持的产品,这不仅增加了用户粘性,也推动了 Firefox 作为创新平台的形象。</p>
<h3 id="firefox-的技术革新与竞争2011-2015">Firefox 的技术革新与竞争2011-2015<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的技术革新与竞争2011-2015" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="多进程架构">多进程架构<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#多进程架构" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 最初采用单进程架构,即所有标签页、扩展和插件都在一个进程中运行。这导致了性能问题,尤其是当某个标签页崩溃时,会影响整个浏览器的稳定性。与采用多进程架构的 Chrome 相比Firefox 在性能和稳定性方面处于劣势。</p>
<p>2011 年Mozilla 启动了<strong>Electrolysise10s项目逐步将 Firefox 转向多进程架构</strong>。通过这一架构,每个标签页、插件和扩展都在独立的进程中运行,从而提高浏览器的稳定性、安全性和性能。这一转变帮助 Firefox 缩小了与竞争对手 Chrome 在性能上的差距。</p>
<h4 id="扩展支持的改进">扩展支持的改进<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#扩展支持的改进" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>为了提升扩展的兼容性Firefox 逐步过渡到<strong>WebExtensions API</strong>,该 API 与 Google Chrome 的扩展框架兼容。这使得开发者可以更轻松地将 Chrome 扩展移植到 Firefox 上,丰富了 Firefox 的扩展生态。</p>
<p>这一变化使得 Firefox 能够继续保持其高度可定制的特性,同时确保扩展的安全性和性能。与 Chrome 的兼容性也使得用户可以在两个平台之间无缝切换扩展,提升了用户体验。</p>
<h4 id="firefox-os-项目">Firefox OS 项目<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-os-项目" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Mozilla 在此期间也探索了移动平台的可能性,推出了基于 Web 技术的移动操作系统<strong>Firefox OS</strong>。该系统主要面向低成本的智能手机市场,旨在通过开放的 Web 技术推动移动互联网的普及。尽管 Firefox OS 未能在市场上取得预期的成功,并于 2016 年停止开发,但其在推动 Web 技术向移动端发展的过程中贡献显著。</p>
<h3 id="firefox-的现代化演变2016--至今">Firefox 的现代化演变2016- 至今)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的现代化演变2016--至今" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="quantum-项目的引入">Quantum 项目的引入<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#quantum-项目的引入" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>2017 年Mozilla 推出了<strong>Quantum 项目</strong>,这是 Firefox 现代化演变的标志性事件。Quantum 项目通过重构 Firefox 的浏览器引擎,带来了性能的质变提升。该项目引入了并行处理和多核优化,确保 Firefox 可以更高效地利用现代硬件资源。</p>
<p>Quantum 项目显著提升了 Firefox 的速度和内存管理效率特别是在处理复杂网页和多任务操作时的表现。Quantum 还引入了基于 GPU 的图形渲染,进一步提升了网页的加载速度和流畅度,使得 Firefox 能够与 Chrome 等浏览器竞争。</p>
<h4 id="引入-servo-技术">引入 Servo 技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#引入-servo-技术" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 在 Quantum 项目中部分采用了由 Mozilla 开发的<strong>Servo 引擎</strong>技术。Servo 是一个基于 Rust 语言的新型浏览器引擎具备高并发处理和安全特性。Rust 语言的内存安全特性减少了传统 C/C++ 代码中的漏洞风险,这使得 Firefox 在性能与安全性上更具优势。</p>
<p>Servo 的引入使得 Firefox 能够更高效地进行并发任务处理,优化了渲染速度和内存使用,并为未来进一步提升性能提供了坚实基础。</p>
<h4 id="隐私保护的创新">隐私保护的创新<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#隐私保护的创新" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>随着用户隐私日益受到关注Firefox 通过不断引入新的隐私保护功能进一步巩固了其在隐私领域的领先地位。2018 年Firefox 推出了<strong>增强型跟踪保护Enhanced Tracking Protection</strong>,旨在阻止广告追踪器和第三方 Cookie从而保护用户隐私。</p>
<p>Mozilla 还推出了专注于隐私保护的浏览器<strong>Firefox Focus</strong>,它默认启用广告拦截和隐私保护功能,不保留浏览记录,成为注重隐私用户的首选浏览器之一。</p>
<h4 id="逐步淘汰旧技术">逐步淘汰旧技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#逐步淘汰旧技术" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>随着 Web 技术的发展Firefox 逐步淘汰了一些过时的技术,如<strong>Adobe Flash</strong>。Mozilla 通过推动现代 Web 标准(如<strong>HTML5</strong><strong>WebAssembly</strong><strong>WebRTC</strong>)的采用,促进了 Web 平台的进步。WebAssembly 的引入,使得开发者能够在浏览器中运行接近原生性能的代码,为高性能 Web 应用提供了强大的支持。</p>
<h2 id="firefox-的架构">Firefox 的架构<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的架构" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<h3 id="多进程架构的概述">多进程架构的概述<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#多进程架构的概述" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p><strong>多进程架构是现代浏览器中重要的设计模式</strong>,通过将不同功能模块分离到独立的进程中,提高浏览器的稳定性、安全性和性能。<strong>Electrolysise10s项目</strong>是 Mozilla 为 Firefox 引入多进程架构的关键项目,旨在解决传统单进程浏览器存在的崩溃、性能和安全性问题。通过 e10sFirefox 在架构上经历了重大革新,将用户界面、内容渲染和后台任务处理分布在多个独立的进程中,从而显著提升了用户体验。</p>
<h4 id="electrolysise10s项目">Electrolysise10s项目<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#electrolysise10s项目" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Electrolysis</strong>项目的推出,是 Firefox 从单进程架构转向多进程架构的里程碑。单进程浏览器模式将所有页面、插件和 UI 渲染放在同一进程中导致一个标签页或插件的崩溃会引发整个浏览器的崩溃。Electrolysis 通过将浏览器的 UI 和页面内容分离到不同的进程中,解决了这一问题。</p>
<p>核心目标:</p>
<ul>
<li><strong>稳定性</strong>:通过进程隔离,确保单个页面的崩溃不会影响其他标签页或浏览器主进程。</li>
<li><strong>性能</strong>分离进程后Firefox 能够更高效地分配资源,避免单个任务占用过多系统资源。</li>
<li><strong>安全性</strong>:独立的内容进程运行在受限的权限范围内,减少了恶意脚本对系统造成威胁的可能性。</li>
</ul>
<h4 id="进程模型设计">进程模型设计<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#进程模型设计" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 的多进程架构将不同的功能模块分配到独立的进程中,优化了浏览器的资源管理和任务调度。</p>
<ul>
<li><strong>主进程</strong><strong>浏览器主进程</strong>Browser Process负责管理 Firefox 的 UI包括标签页、窗口、工具栏和菜单。同时它也负责处理网络请求、文件下载和各个进程之间的协调工作。主进程起到了控制中心的作用确保浏览器的核心功能顺畅运行。</li>
<li><strong>内容进程</strong>:每个标签页在一个独立的<strong>内容进程</strong>中渲染和执行页面内容,避免了页面之间的相互干扰。每个内容进程负责解析 HTML、CSS 和 JavaScript执行页面脚本并进行 DOM 操作。通过这种设计,内容进程的崩溃不会影响浏览器的主进程或其他标签页的运行,极大提升了浏览器的稳定性。</li>
<li><strong>GPU 进程</strong><strong>GPU 进程</strong>Graphics Processing Unit Process是专门用于处理与图形相关的任务如页面渲染、动画和视频播放等。通过将这些资源密集型任务交给 GPU 处理Firefox 能够更高效地渲染复杂的网页内容,同时减少对 CPU 的依赖,提升整体性能。</li>
</ul>
<p>此外Firefox 的架构还包括一些辅助进程,例如:</p>
<ul>
<li><strong>插件进程</strong>:负责运行传统的浏览器插件(如 Flash这些插件与页面内容隔离避免其崩溃影响浏览器稳定性。</li>
<li><strong>扩展进程</strong>:负责执行 Firefox 扩展程序,使其与页面内容独立运行,增强浏览器的安全性和稳定性。</li>
</ul>
<h3 id="多进程架构的优缺点">多进程架构的优缺点<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#多进程架构的优缺点" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p><strong>优点</strong></p>
<ul>
<li><strong>稳定性提升</strong>:多进程架构显著提升了 Firefox 的稳定性。每个标签页的内容进程独立运行,这意味着即使一个页面崩溃,其他标签页和浏览器本身仍能正常工作。主进程仅负责用户界面的管理和进程之间的通信,从而减少了浏览器整体崩溃的可能性。</li>
<li><strong>安全性增强</strong>多进程架构为安全性提供了更高的保障。内容进程运行在一个受限的环境沙盒不能直接访问用户的系统资源。这种隔离有效防止了恶意网站或脚本通过浏览器对用户的系统进行攻击。此外进程间的隔离机制进一步减少了跨站脚本攻击XSS和跨站请求伪造CSRF等网络攻击的风险。</li>
<li><strong>并行处理</strong>通过将渲染和脚本执行任务分配到多个进程中Firefox 能够更好地利用现代多核 CPU 的优势。各个进程可以并行执行,提升了整体的浏览性能和响应速度,特别是在多任务处理和高负载情况下。</li>
<li><strong>资源分配优化</strong>:多进程模型使 Firefox 能够更细粒度地控制资源分配。每个进程独立管理内存和 CPU 资源,防止单个任务占用过多资源。这对于复杂的 Web 应用和动态页面特别重要,避免了单个页面造成浏览器性能下降的情况。</li>
</ul>
<p><strong>缺点</strong></p>
<ul>
<li><strong>内存占用较高</strong>:多进程架构的一个主要缺点是内存占用较高。每个独立进程都会占用一定的系统资源,尤其是在同时打开多个标签页时,每个内容进程独立运行,导致内存需求增大。对于低内存设备或需要长时间打开大量标签页的用户,这可能会影响系统的性能。</li>
<li><strong>启动速度影响</strong>:多进程架构可能在某些情况下影响浏览器的启动速度,特别是在需要为每个进程分配资源并初始化时,可能会增加启动延迟。不过,随着硬件性能的提升和 Firefox 的持续优化,这一问题已逐渐得到缓解。</li>
</ul>
<h2 id="firefox-的渲染机制">Firefox 的渲染机制<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的渲染机制" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<h3 id="从输入-url-到页面渲染的详细过程">从输入 URL 到页面渲染的详细过程<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#从输入-url-到页面渲染的详细过程" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p>当用户在浏览器中输入 URL 并按下回车键时浏览器开始从请求页面到呈现页面内容的整个渲染过程。Firefox 使用其独特的<strong>Gecko 渲染引擎</strong>来解析和渲染页面,具体过程如下:</p>
<h4 id="请求阶段">请求阶段<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#请求阶段" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li>DNS 解析与 HTTP 请求:
<ul>
<li>首先Firefox 会通过<strong>DNS 解析</strong>将用户输入的域名(如 <code>example.com</code>)转换为对应的 IP 地址。获取 IP 地址后,浏览器通过<strong>TCP 连接</strong>与服务器建立通信。如果是 HTTPS 请求,还会进行<strong>TLS 握手</strong>来确保通信的加密安全。</li>
<li>随后,浏览器向服务器发起<strong>HTTP/HTTPS 请求</strong>,请求获取页面的资源。这些资源包括 HTML 文档、CSS 文件、JavaScript 脚本、图片等。</li>
</ul>
</li>
</ul>
<h4 id="渲染流程">渲染流程<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#渲染流程" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>在获取页面资源后Firefox 开始进入渲染阶段,将资源转化为用户可见的页面内容。</p>
<ul>
<li><strong>HTML 解析与 DOM 树生成</strong>:浏览器首先解析 HTML 文档并构建<strong>DOM 树</strong>Document Object Model。DOM 树是页面内容的内部表示结构,每个 HTML 标签对应 DOM 树中的一个节点。这一步骤为页面的逻辑和结构提供基础。</li>
<li><strong>CSS 解析与 CSSOM 生成</strong>:同时,浏览器解析外部的 CSS 样式文件以及内联样式,生成<strong>CSSOM 树</strong>CSS Object Model。CSSOM 树描述了页面中每个 DOM 元素的样式属性。DOM 树和 CSSOM 树结合,决定页面元素如何呈现。</li>
<li><strong>布局与绘制</strong>:通过结合 DOM 树和 CSSOM 树,浏览器生成<strong>渲染树</strong>,表示页面中需要显示的可见元素。接着进入**布局Layout<strong>阶段,浏览器计算每个元素的大小、位置,确定它们在页面中的精确布局。完成布局后,浏览器进入</strong>绘制Painting**阶段,将渲染树的内容绘制到屏幕上。这包括绘制元素的文本、颜色、边框、背景图片等视觉效果。</li>
<li><strong>合成与图层管理</strong>为了提升复杂页面的渲染效率Firefox 将页面内容分割成多个图层,通过<strong>GPU 进程</strong>进行图层合成和渲染。页面中的动画、视频、图形处理都会通过<strong>GPU 加速</strong>,以提高渲染速度和流畅度。最后,浏览器将这些图层组合在一起,呈现在用户屏幕上。</li>
</ul>
<h3 id="gecko-渲染引擎">Gecko 渲染引擎<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#gecko-渲染引擎" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="gecko-概述">Gecko 概述<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#gecko-概述" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Gecko</strong>是 Mozilla 专为 Firefox 开发的渲染引擎,用于解析和渲染 HTML、CSS、JavaScript 以及其他 Web 内容。作为一个完全支持现代 Web 标准的引擎Gecko 支持最新的 HTML5、CSS3、JavaScriptES6+)等技术,并且经过了多年的迭代优化。</p>
<p>Gecko 负责处理 Web 内容的呈现,从 HTML 解析、DOM 树构建到最终的页面绘制。它与 Firefox 的 JavaScript 引擎<strong>SpiderMonkey</strong>协同工作,确保动态内容能够快速渲染。</p>
<h4 id="servo-项目的引入">Servo 项目的引入<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#servo-项目的引入" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Servo</strong>是由 Mozilla 开发的基于 Rust 语言的浏览器引擎旨在利用现代多核处理器的优势来并行处理页面渲染任务。Servo 具备较高的并发处理能力和内存安全性,能够避免许多传统引擎中的内存管理问题。</p>
<p><strong>Quantum 项目</strong>Firefox 逐步将<strong>Servo</strong>的技术引入到<strong>Gecko</strong>中。通过这种混合架构Firefox 的渲染速度大幅提升特别是在多核处理器上Servo 的并发处理特性让 Firefox 在渲染复杂页面时更加高效和流畅。</p>
<p>Quantum 项目引入了 Servo 的部分技术,比如图层管理和并行化 CSS 处理,极大地改善了渲染性能和内存管理,使得 Firefox 在与 Chrome 等竞争对手的比较中不再处于劣势。</p>
<h3 id="spidermonkey-javascript-引擎">SpiderMonkey JavaScript 引擎<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#spidermonkey-javascript-引擎" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="spidermonkey-概述">SpiderMonkey 概述<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#spidermonkey-概述" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>SpiderMonkey</strong>是 Firefox 的 JavaScript 引擎,专门用于解析、编译和执行 JavaScript 代码。它支持现代 JavaScript 的所有功能,包括 ES6 及以后的标准。SpiderMonkey 在性能优化方面做了大量工作,以确保能够高效处理复杂的 Web 应用。</p>
<ul>
<li><strong>即时编译JITJust-in-Time</strong>SpiderMonkey 使用了即时编译技术,将 JavaScript 代码在运行时编译为机器码,这样可以显著提升执行速度,尤其是在处理复杂的动态脚本时。</li>
<li>SpiderMonkey 通过优化代码执行和内存管理,确保页面脚本的快速执行。</li>
</ul>
<h4 id="性能优化">性能优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#性能优化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>SpiderMonkey 在性能优化上进行了许多改进,尤其是<strong>垃圾回收</strong>Garbage Collection机制。</p>
<ul>
<li><strong>增量垃圾回收</strong>传统的垃圾回收策略会在回收时暂停应用的执行导致用户在运行时感受到明显的卡顿。为了解决这一问题SpiderMonkey 引入了<strong>增量垃圾回收</strong>机制,通过分阶段、逐步清理内存中的无效对象,减少垃圾回收过程对页面性能的影响。</li>
<li><strong>内存管理优化</strong>SpiderMonkey 通过精细的内存管理策略,优化了对对象的创建和销毁,提高了浏览器的整体性能和响应能力。尤其是在处理大规模 JavaScript 对象时,这种优化能够显著减少内存泄漏的风险,并保持页面的流畅运行。</li>
</ul>
<h2 id="firefox-的性能优化">Firefox 的性能优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的性能优化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<p>优化页面和网络性能是提升 Firefox 浏览器中 Web 应用响应速度和用户体验的关键步骤。通过合理的资源管理、延迟加载技术以及网络请求优化,开发者可以大幅减少加载时间、提升页面交互流畅度。此外,使用<strong>Firefox DevTools</strong>进行性能分析,可以帮助开发者识别和解决性能瓶颈。</p>
<h3 id="页面性能优化">页面性能优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#页面性能优化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="lazy-loading-与资源延迟加载">Lazy Loading 与资源延迟加载<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#lazy-loading-与资源延迟加载" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Lazy Loading</strong>(懒加载)是一种优化页面加载性能的技术,主要针对图片、视频等非关键资源。懒加载技术使得资源只在用户滚动到页面相应部分时才加载,而不是在页面初次加载时就全部下载。这种方式有效减少了页面的初次渲染时间,加速了页面的可用性。</p>
<ul>
<li><strong>应用场景</strong>图片、视频、iframe 等资源。</li>
<li><strong>实现方式</strong>:在 HTML 中使用 <code>loading=&quot;lazy&quot;</code> 属性,或通过 JavaScript 动态加载资源。</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="html" data-theme="github-light github-dark"><code data-language="html" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">&lt;</span><span style="--shiki-light:#22863A;--shiki-dark:#85E89D;">img</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> src</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;image.jpg&quot;</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> loading</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;lazy&quot;</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> alt</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Lazy loaded image&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></span></span></code></pre></figure>
<p>通过这种延迟加载,用户在没有浏览到相应内容时不会浪费带宽下载资源,从而提高了页面的响应速度。</p>
<h4 id="减少回流与重绘">减少回流与重绘<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#减少回流与重绘" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li>
<p><strong>回流Reflow</strong>:回流发生在页面的布局发生变化时,浏览器需要重新计算元素的大小、位置并重新绘制页面。这是一个性能开销较大的过程,因此需要尽量减少不必要的回流。</p>
<p><strong>优化策略</strong></p>
<ul>
<li>避免逐步操作 DOM尽量批量更新。可以使用 <code>DocumentFragment</code> 或批量操作 CSS 属性来减少 DOM 操作的次数。</li>
<li>避免频繁读取导致回流的属性(如 <code>offsetHeight</code><code>scrollTop</code> 等),应将它们的读取和写入操作分开。</li>
</ul>
</li>
<li>
<p><strong>重绘Repaint</strong>:重绘发生在元素的视觉样式发生变化(如颜色、背景等),但不影响布局时。虽然重绘的开销小于回流,但频繁的重绘仍然会影响性能。</p>
<p><strong>优化策略</strong></p>
<ul>
<li>将影响页面显示的操作尽量集中在一次操作中完成,避免频繁更新样式。</li>
<li>使用 <code>transform</code><code>opacity</code> 属性进行动画和视觉效果处理,因为这些属性不会触发回流或重绘。</li>
</ul>
</li>
</ul>
<h3 id="网络性能优化">网络性能优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#网络性能优化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="http2-与-http3-支持">HTTP/2 与 HTTP/3 支持<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#http2-与-http3-支持" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>HTTP/2</strong><strong>HTTP/3</strong>是现代的网络协议它们通过多路复用、头部压缩等技术显著提高了网络性能。Firefox 支持这两种协议,开发者可以利用它们减少请求延迟、提高资源传输效率。</p>
<ul>
<li><strong>多路复用</strong>HTTP/2 允许在单一的 TCP 连接上同时传输多个请求和响应,减少了建立多次连接的开销。</li>
<li><strong>头部压缩</strong>HTTP/2 通过对 HTTP 头部进行压缩,减少了数据传输量,提高了响应速度。</li>
<li><strong>HTTP/3</strong>:基于 UDP 的 HTTP/3 协议,通过<strong>QUIC</strong>协议进一步减少了连接建立的延迟,并提高了在网络条件不佳时的传输稳定性。</li>
</ul>
<h4 id="缓存优化">缓存优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#缓存优化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>有效利用浏览器的缓存机制可以显著减少不必要的网络请求,提升页面加载速度。通过合理配置 <code>Cache-Control</code><code>ETag</code> 头部信息,开发者可以确保资源在合适的时间内被缓存,并避免重复加载。</p>
<ul>
<li><strong><code>Cache-Control</code></strong>:指定资源的缓存策略,如 <code>max-age</code> 来定义缓存的有效期。</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="http" data-theme="github-light github-dark"><code data-language="http" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Cache-Control: max-age=3600, public</span></span></code></pre></figure>
<ul>
<li><strong><code>ETag</code></strong>:用于标识资源的版本,当资源未发生变化时,服务器可以返回 304 状态码,指示浏览器使用本地缓存。</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="http" data-theme="github-light github-dark"><code data-language="http" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> ETag: &quot;abc123&quot;</span></span></code></pre></figure>
<p>通过这些缓存优化,浏览器能够减少向服务器请求的次数,加快页面加载速度,尤其是在用户频繁访问相同资源时。</p>
<h4 id="cdn-与预加载">CDN 与预加载<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#cdn-与预加载" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li>
<p><strong>CDN内容分发网络</strong>:使用 CDN 将静态资源分发到多个地理位置的服务器上,确保用户能够从离自己最近的服务器获取资源,减少了传输延迟。</p>
<p><strong>优化策略</strong></p>
<ul>
<li>将静态资源如图片、CSS、JavaScript 文件)托管到 CDN。</li>
<li>确保 CDN 能够根据用户的地理位置选择最优的资源节点进行分发。</li>
</ul>
</li>
<li>
<p><strong>预加载技术</strong>:通过预加载关键资源,可以确保浏览器在用户需要时已经提前下载了这些资源,从而减少等待时间。</p>
</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="http" data-theme="github-light github-dark"><code data-language="http" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> &lt;</span><span style="--shiki-light:#22863A;--shiki-dark:#85E89D;">link</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> rel</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;preload&quot;</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> href</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;/style.css&quot;</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> as</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;style&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></span></span></code></pre></figure>
<p>预加载可以显著加快关键资源(如 CSS 文件、字体、重要的 JavaScript 库)的加载速度,优化用户的首次访问体验。</p>
<h2 id="firefox-的安全机制">Firefox 的安全机制<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的安全机制" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<p>Firefox 通过多层次的安全机制来保障用户的隐私和系统安全,防止恶意网站或代码对用户造成危害。这些安全机制包括<strong>同源策略SOP</strong><strong>沙盒隔离机制</strong><strong>内容安全策略CSP</strong>,共同为用户提供全面的浏览器安全保障。</p>
<h3 id="同源策略sop-same-origin-policy">同源策略SOP, Same-Origin Policy<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#同源策略sop-same-origin-policy" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="同源策略">同源策略<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#同源策略" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>同源策略</strong>Same-Origin Policy, SOP是 Web 浏览器最基本的安全机制之一。它限制了来自不同来源的网页内容之间的交互,以防止恶意网站访问或篡改用户的敏感数据。同源策略通过控制文档、脚本和资源的交互权限,确保用户数据的隐私和安全。</p>
<ul>
<li>
<p><strong>同源的定义</strong>:同源指的是两个 URL 具有相同的<strong>协议</strong>(如 HTTP/HTTPS<strong>域名</strong><strong>端口</strong>。如果这些信息中有任何一个不同,则被认为是不同源。</p>
<p>例如,<code>https://example.com:443</code><code>http://example.com</code><code>https://sub.example.com</code> 都被视为不同源,这意味着它们之间不能直接共享数据。</p>
</li>
<li>
<p><strong>安全性作用</strong>:同源策略通过限制不同来源的网站之间的脚本交互,防止恶意网站读取用户会话、访问其他页面的 Cookie 或通过脚本窃取数据。它是防御跨站脚本XSS和跨站请求伪造CSRF等攻击的重要安全措施。</p>
</li>
</ul>
<h4 id="12-cors跨源资源共享">1.2 CORS跨源资源共享<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#12-cors跨源资源共享" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>尽管同源策略限制了不同来源的交互,但某些情况下,合法的跨域请求仍然是必要的。**CORS跨源资源共享**机制允许服务器明确控制哪些外部来源可以访问其资源。</p>
<ul>
<li><strong>CORS 的工作机制</strong>:当浏览器发出跨域请求时,服务器可以在响应头中设置 <code>Access-Control-Allow-Origin</code>,指定哪些来源可以访问资源。如果跨域请求被允许,浏览器才会继续处理请求。</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="http" data-theme="github-light github-dark"><code data-language="http" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Access-Control-Allow-Origin: https://example.com</span></span></code></pre></figure>
<p>对于复杂请求,浏览器会先发起<strong>预检请求</strong>OPTIONS 方法),询问服务器是否允许跨域请求。服务器通过返回适当的 CORS 响应头部来决定是否允许跨源访问。</p>
<p>通过 CORS服务器能够精细控制跨域请求的权限确保合法请求被接受而非法请求则被拒绝从而进一步增强了跨域资源共享的安全性。</p>
<h3 id="沙盒隔离机制">沙盒隔离机制<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#沙盒隔离机制" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="内容进程的沙盒化">内容进程的沙盒化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#内容进程的沙盒化" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>沙盒化</strong>是一种有效的安全技术通过将运行的程序与系统核心资源隔离开来限制其对操作系统的访问权限。Firefox 使用<strong>多进程架构</strong>,每个网页的内容渲染都在<strong>内容进程</strong>中进行,而内容进程被放置在一个受限的沙盒环境中运行。</p>
<ul>
<li><strong>沙盒隔离的作用:</strong> 内容进程只能访问特定的、受限的资源,它不能直接读取或写入用户的文件系统、摄像头、麦克风等关键系统资源。即便网页中包含恶意代码,由于沙盒的隔离作用,攻击者也难以突破浏览器的限制,损害用户的系统安全。</li>
<li><strong>减少恶意威胁:</strong> 沙盒化机制有效阻止了通过浏览器攻击系统核心的企图,使得恶意网站、脚本无法获取到系统敏感资源。它还能够减少浏览器插件或第三方扩展中的潜在安全漏洞对系统的威胁。</li>
</ul>
<p>通过内容进程的沙盒化Firefox 在保护用户免受恶意网站攻击方面大大增强了安全性。</p>
<h3 id="内容安全策略csp-content-security-policy">内容安全策略CSP, Content Security Policy<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#内容安全策略csp-content-security-policy" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p><strong>内容安全策略</strong>Content Security Policy, CSP是用于防止跨站脚本XSS和数据注入攻击的浏览器安全机制。CSP 允许 Web 开发者通过设置 HTTP 头部,明确指定哪些外部资源可以加载,哪些资源应被禁止。</p>
<h4 id="防止-xss-攻击">防止 XSS 攻击<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#防止-xss-攻击" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>**跨站脚本攻击XSS**是最常见的网络攻击之一攻击者通过在网页中插入恶意脚本窃取用户数据或执行不受信任的操作。CSP 通过限制哪些外部脚本可以加载,帮助开发者防止这些攻击。</p>
<ul>
<li>
<p><strong>CSP 的工作机制</strong>:开发者可以在响应头中指定允许加载的资源源,例如脚本、样式、图像等。只有符合 CSP 策略的资源才会被浏览器加载。</p>
<p>示例 CSP 头部:</p>
</li>
</ul>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="http" data-theme="github-light github-dark"><code data-language="http" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Content-Security-Policy: script-src 'self' https://trusted.cdn.com</span></span></code></pre></figure>
<p>在上面的示例中,只有来自当前站点(<code>self</code>)和受信任的 CDN<code>https://trusted.cdn.com</code>)的脚本才能被加载,其他来源的脚本将被阻止执行。</p>
<ul>
<li><strong>防止恶意注入</strong>通过严格控制资源加载的来源CSP 可以有效阻止通过注入 HTML、JavaScript 或第三方插件带来的潜在安全威胁,尤其是那些试图窃取用户会话或操控页面行为的攻击。</li>
</ul>
<p>CSP 不仅是防御 XSS 攻击的关键工具,还能用于加强其他安全防护措施,防止未经授权的内容加载到网页中。</p>
<h2 id="firefox-扩展开发">Firefox 扩展开发<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-扩展开发" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<p>Firefox 通过<strong>WebExtensions API</strong>提供了一个强大且灵活的扩展开发平台,允许开发者创建**与 Chrome 等其他浏览器兼容的跨浏览器扩展。**开发者可以通过 Firefox 的工具和平台进行调试和发布扩展,确保其符合安全和性能标准。</p>
<h3 id="webextensions-api">WebExtensions API<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#webextensions-api" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p><strong>WebExtensions API</strong>是 Firefox 的标准扩展开发框架,旨在简化扩展开发,并与其他主流浏览器(如 Chrome、Edge 和 Opera的扩展生态系统兼容。WebExtensions API 使得开发者能够编写一个扩展,在多个浏览器上运行,大大降低了开发和维护的复杂性。</p>
<h4 id="扩展兼容性">扩展兼容性<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#扩展兼容性" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 支持基于<strong>WebExtensions API</strong>的扩展,与 Chrome 等浏览器的扩展系统高度兼容。开发者可以使用几乎相同的代码库在不同浏览器上发布扩展,这使得跨浏览器扩展的开发变得更加方便和高效。</p>
<p>WebExtensions API 通过统一的接口,提供访问浏览器的核心功能(如标签管理、网络请求拦截、书签操作等)。这意味着开发者可以为多个浏览器创建同一个扩展,而无需为每个浏览器单独开发版本。</p>
<h4 id="manifestjson-文件">manifest.json 文件<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#manifestjson-文件" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>每个 Firefox 扩展都有一个<strong>manifest.json</strong>文件,它是扩展的核心配置文件,定义了扩展的权限、图标、背景脚本、内容脚本和其他关键信息。它的结构与 Chrome 扩展的 manifest 文件非常相似,使得开发者能够轻松适配其他浏览器。</p>
<p><strong>基本结构</strong></p>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="json" data-theme="github-light github-dark"><code data-language="json" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">{</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;manifest_version&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">2</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;name&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;My Firefox Extension&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;version&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;1.0&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;description&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;An example of a Firefox extension&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;icons&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: {</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;48&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;icons/icon-48.png&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;96&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;icons/icon-96.png&quot;</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;permissions&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;storage&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;activeTab&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;tabs&quot;</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> ],</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;background&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: {</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;scripts&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;background.js&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">]</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;content_scripts&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;matches&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;*://*.example.com/*&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">],</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;js&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;content.js&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">]</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> ]</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">}</span></span></code></pre></figure>
<p><strong>关键字段</strong></p>
<ul>
<li><strong><code>name</code></strong>:扩展的名称。</li>
<li><strong><code>version</code></strong>:扩展的版本号。</li>
<li><strong><code>permissions</code></strong>:定义扩展所需的权限,如访问标签页、存储数据、修改页面内容等。</li>
<li><strong><code>background</code></strong>:指定运行在后台的脚本,用于处理事件和状态。</li>
<li><strong><code>content_scripts</code></strong>:注入到特定页面的脚本,用于操作页面 DOM 或修改其行为。</li>
</ul>
<p>通过 manifest 文件,开发者可以定义扩展的行为和所需的浏览器权限,以确保功能的实现和资源的适当管理。</p>
<h3 id="开发与调试">开发与调试<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#开发与调试" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="firefox-devtools">Firefox DevTools<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-devtools" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>Firefox 提供了强大的<strong>DevTools</strong>帮助开发者调试扩展的运行状态。DevTools 可以调试扩展的<strong>内容脚本</strong><strong>后台脚本</strong>,分析其执行流程,查看网络请求,甚至调试扩展与浏览器之间的消息传递。</p>
<ul>
<li>
<p><strong>调试内容脚本</strong>:开发者可以通过 DevTools 的“Inspector”选项卡查看页面上注入的内容脚本是否正确执行以及是否对 DOM 进行了预期的修改。</p>
</li>
<li>
<p><strong>调试后台脚本</strong>:通过 DevTools 中的“Debugger”工具开发者可以调试后台脚本设置断点、查看变量、跟踪事件响应等。后台脚本是扩展中的长期运行脚本常用于管理事件监听和状态维护。</p>
<p><strong>示例:调试后台脚本</strong></p>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="javascript" data-theme="github-light github-dark"><code data-language="javascript" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">chrome.runtime.onInstalled.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">addListener</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">() {</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Extension installed&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">);</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">});</span></span>
<span data-line> </span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">chrome.tabs.onUpdated.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">addListener</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">tabId</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">changeInfo</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">tab</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) {</span></span>
<span data-line><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> if</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> (changeInfo.status </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">===</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;complete&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) {</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Tab updated:&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, tab.url);</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">});</span></span></code></pre></figure>
</li>
</ul>
<p>通过 DevTools开发者可以轻松排查扩展中的问题确保它们在不同浏览器上下文中正确运行。</p>
<h4 id="扩展开发流程">扩展开发流程<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#扩展开发流程" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li><strong>安装扩展</strong>:在 Firefox 的扩展管理界面,开发者可以将扩展以开发者模式加载到浏览器中,无需发布到 AMO。这可以方便开发和测试过程。</li>
<li><strong>调试与日志</strong>:开发者可以在扩展中使用 <code>console.log</code> 进行调试,所有的日志输出都可以通过 DevTools 的“Console”面板查看。</li>
</ul>
<h3 id="发布扩展">发布扩展<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#发布扩展" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<h4 id="发布到-amo-平台">发布到 AMO 平台<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#发布到-amo-平台" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>**addons.mozilla.orgAMO**是 Mozilla 官方的扩展发布平台。开发者在完成扩展开发后,可以通过 AMO 将扩展发布给全球用户。与 Chrome Web Store 相比Firefox 对扩展的审查要求更为严格,重点关注隐私和安全性。</p>
<ul>
<li>审查流程:
<ul>
<li>扩展提交到 AMO 后,会经过自动和手动审查。审查主要检测扩展的代码是否包含恶意行为,是否有不必要的权限请求,以及是否符合 Mozilla 的隐私政策。</li>
<li><strong>权限审核</strong>Firefox 对扩展请求的权限有着严格的要求,开发者必须在 manifest 文件中明确声明所需权限,并确保这些权限的使用符合隐私保护要求。</li>
</ul>
</li>
</ul>
<h4 id="32-扩展的打包和上传">3.2 扩展的打包和上传<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#32-扩展的打包和上传" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<ul>
<li><strong>打包扩展</strong>:开发者需要将扩展打包为 <code>.zip</code><code>.xpi</code> 文件格式。在开发完成后,可以通过扩展管理页面或命令行工具进行打包。</li>
<li><strong>上传扩展</strong>:进入 AMO 开发者页面后,开发者可以上传打包好的扩展。上传后,扩展将进入审查队列,审查通过后即可公开发布。</li>
<li><strong>开发者控制面板</strong>AMO 为开发者提供了详细的扩展管理控制面板,开发者可以管理扩展的版本更新、用户反馈和下载统计。</li>
</ul>
<h2 id="firefox-的前沿技术">Firefox 的前沿技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#firefox-的前沿技术" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h2>
<p>Firefox 始终致力于推动 Web 技术的前沿发展,并为开发者提供功能强大的平台,以构建高效、现代化的 Web 应用。**渐进式 Web 应用PWA<strong></strong>WebAssemblyWASM**是两项重要的前沿技术Firefox 通过持续优化对这些技术的支持,推动 Web 应用的性能、可用性和开发效率的提升。</p>
<h3 id="渐进式-web-应用pwa-progressive-web-app">渐进式 Web 应用PWA, Progressive Web App<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#渐进式-web-应用pwa-progressive-web-app" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p>渐进式 Web 应用PWA旨在提供类原生应用的 Web 体验,通过增加离线支持、推送通知和跨设备兼容等功能,使 Web 应用更加灵活、强大。Firefox 对 PWA 的支持为用户带来了高效、流畅的使用体验,增强了 Web 应用的功能性。</p>
<h4 id="service-workers-与缓存">Service Workers 与缓存<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#service-workers-与缓存" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Service Workers</strong> 是 PWA 的核心技术之一运行在浏览器后台独立于主页面提供了强大的功能如离线支持、缓存管理和通知推送。Firefox 对 Service Workers 的支持使得 PWA 能够在网络不稳定甚至无网络的情况下正常运行。</p>
<ul>
<li>
<p><strong>离线支持</strong>:通过 Service WorkersPWA 可以缓存关键资源,并在用户离线时使用这些缓存资源来渲染页面。缓存的资源可以包括 HTML、CSS、JavaScript 和图片等,确保用户能够在没有网络连接的情况下使用应用。</p>
<p><strong>示例Service Worker 的缓存机制</strong></p>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="javascript" data-theme="github-light github-dark"><code data-language="javascript" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">self.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">addEventListener</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'install'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, (</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">event</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=></span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> event.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">waitUntil</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> caches.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">open</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'my-cache'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">then</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">((</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">cache</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=></span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> return</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> cache.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">addAll</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">([</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> '/'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> '/index.html'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> '/styles.css'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> '/script.js'</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> ]);</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> );</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">});</span></span>
<span data-line> </span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">self.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">addEventListener</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'fetch'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, (</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">event</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=></span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> event.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">respondWith</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> caches.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">match</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(event.request).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">then</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">((</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">response</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=></span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> return</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> response </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">||</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> fetch</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(event.request);</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> );</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">});</span></span></code></pre></figure>
</li>
<li>
<p><strong>通知推送</strong>Service Workers 还能接收推送通知,即使 PWA 未被打开时,用户也能收到消息。这使得 PWA 具备了与原生应用类似的互动功能,增强了用户参与度。</p>
</li>
</ul>
<h4 id="manifest-文件与图标管理">Manifest 文件与图标管理<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#manifest-文件与图标管理" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p><strong>Manifest 文件</strong> 是 PWA 的配置文件,用于定义应用的名称、图标、启动 URL、显示模式如全屏或固定窗口、主题颜色等。通过 Manifest 文件PWA 能够在用户设备上创建一个快捷方式,提供类似原生应用的启动体验。</p>
<ul>
<li>
<p><strong>图标与启动配置</strong>Manifest 文件定义了 PWA 的图标、启动画面以及显示模式。通过这些配置PWA 不仅可以在桌面或移动设备上创建图标,还能够控制应用在不同设备上的呈现方式,如全屏模式运行或以固定窗口形式显示。</p>
<p><strong>示例manifest.json 文件</strong></p>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="json" data-theme="github-light github-dark"><code data-language="json" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">{</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;name&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;My Progressive Web App&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;short_name&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;MyPWA&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;start_url&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;/index.html&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;icons&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;src&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;/icons/icon-192.png&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;sizes&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;192x192&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;type&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;image/png&quot;</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;src&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;/icons/icon-512.png&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;sizes&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;512x512&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;type&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;image/png&quot;</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> ],</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;background_color&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;#ffffff&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;theme_color&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;#2196F3&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> &quot;display&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;standalone&quot;</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">}</span></span></code></pre></figure>
</li>
<li>
<p><strong>Firefox 对 PWA 的支持</strong>Firefox 允许用户将 PWA 应用安装到设备桌面,并通过 Manifest 文件管理图标和启动行为提供更接近原生应用的用户体验。此外Firefox 的**开发者工具DevTools**中还包含 PWA 调试功能,开发者可以检查缓存、查看 Service Worker 的状态等。</p>
</li>
</ul>
<h3 id="webassemblywasm">WebAssemblyWASM<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#webassemblywasm" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h3>
<p><strong>WebAssemblyWASM</strong> 是一种二进制指令格式允许开发者在浏览器中运行接近原生性能的代码。Firefox 对 WebAssembly 的支持,极大提升了浏览器中运行复杂任务的效率,如 3D 渲染、加密运算和高性能游戏。</p>
<h4 id="webassembly-在-firefox-中的支持">WebAssembly 在 Firefox 中的支持<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#webassembly-在-firefox-中的支持" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>WebAssembly 提供了运行高效代码的能力,使得浏览器不仅能够处理传统的 Web 任务,还能承担一些计算密集型的操作,如图像处理、机器学习模型训练、游戏渲染等。</p>
<ul>
<li><strong>高性能计算</strong>WASM 通过将高级语言(如 C、C++、Rust编译成高效的字节码并在浏览器中运行从而实现接近原生性能的执行速度。它专为性能而设计能够在浏览器中快速运行复杂算法、3D 图形处理和实时视频编辑等任务。</li>
<li><strong>跨平台支持</strong>WASM 是一种跨浏览器、跨平台的技术Firefox 和其他主流浏览器(如 Chrome、Edge都支持 WebAssembly这使得开发者能够编写一次代码在多个平台上高效运行。</li>
</ul>
<h4 id="javascript-与-wasm-的互操作">JavaScript 与 WASM 的互操作<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#javascript-与-wasm-的互操作" class="internal"><svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg></a></h4>
<p>虽然 WebAssembly 具有很高的性能,但它与 JavaScript 并不是竞争关系,而是互为补充。开发者可以在 JavaScript 代码中调用 WebAssembly 模块,并通过 API 在两者之间进行数据交换和函数调用。JavaScript 负责页面交互、UI 控制等任务,而 WebAssembly 处理高性能计算任务。</p>
<ul>
<li>
<p><strong>调用 WASM 模块</strong>:开发者可以通过 JavaScript 加载 WASM 模块,并调用其中的函数。通过这种互操作机制,开发者可以结合两者的优势,构建高效的 Web 应用。</p>
<p><strong>示例JavaScript 调用 WASM 模块</strong></p>
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="javascript" data-theme="github-light github-dark"><code data-language="javascript" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">fetch</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'module.wasm'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">then</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">response</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> =></span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> response.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">arrayBuffer</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">()</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">then</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">bytes</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> =></span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> WebAssembly.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">instantiate</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(bytes)</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">then</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">results</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> =></span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(results.instance.exports.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">add</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">5</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">10</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">)); </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 假设WASM模块中有add函数</span></span>
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">});</span></span></code></pre></figure>
</li>
<li>
<p><strong>数据交换与性能优化</strong>JavaScript 和 WebAssembly 之间的通信性能已经被大幅优化特别是在处理大数据集和复杂的计算时WASM 可以显著提升速度,而 JavaScript 则提供了灵活的控制和接口。</p>
</li>
</ul></article><hr/><div class="page-footer"></div></div><div class="right sidebar"><div class="graph"><h3>关系图谱</h3><div class="graph-outer"><div id="graph-container" data-cfg="{&quot;drag&quot;:true,&quot;zoom&quot;:true,&quot;depth&quot;:1,&quot;scale&quot;:1.1,&quot;repelForce&quot;:0.5,&quot;centerForce&quot;:0.3,&quot;linkDistance&quot;:30,&quot;fontSize&quot;:0.6,&quot;opacityScale&quot;:1,&quot;showTags&quot;:true,&quot;removeTags&quot;:[],&quot;focusOnHover&quot;:false}"></div><button id="global-graph-icon" aria-label="Global Graph"><svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 55 55" fill="currentColor" xml:space="preserve"><path d="M49,0c-3.309,0-6,2.691-6,6c0,1.035,0.263,2.009,0.726,2.86l-9.829,9.829C32.542,17.634,30.846,17,29,17
s-3.542,0.634-4.898,1.688l-7.669-7.669C16.785,10.424,17,9.74,17,9c0-2.206-1.794-4-4-4S9,6.794,9,9s1.794,4,4,4
c0.74,0,1.424-0.215,2.019-0.567l7.669,7.669C21.634,21.458,21,23.154,21,25s0.634,3.542,1.688,4.897L10.024,42.562
C8.958,41.595,7.549,41,6,41c-3.309,0-6,2.691-6,6s2.691,6,6,6s6-2.691,6-6c0-1.035-0.263-2.009-0.726-2.86l12.829-12.829
c1.106,0.86,2.44,1.436,3.898,1.619v10.16c-2.833,0.478-5,2.942-5,5.91c0,3.309,2.691,6,6,6s6-2.691,6-6c0-2.967-2.167-5.431-5-5.91
v-10.16c1.458-0.183,2.792-0.759,3.898-1.619l7.669,7.669C41.215,39.576,41,40.26,41,41c0,2.206,1.794,4,4,4s4-1.794,4-4
s-1.794-4-4-4c-0.74,0-1.424,0.215-2.019,0.567l-7.669-7.669C36.366,28.542,37,26.846,37,25s-0.634-3.542-1.688-4.897l9.665-9.665
C46.042,11.405,47.451,12,49,12c3.309,0,6-2.691,6-6S52.309,0,49,0z M11,9c0-1.103,0.897-2,2-2s2,0.897,2,2s-0.897,2-2,2
S11,10.103,11,9z M6,51c-2.206,0-4-1.794-4-4s1.794-4,4-4s4,1.794,4,4S8.206,51,6,51z M33,49c0,2.206-1.794,4-4,4s-4-1.794-4-4
s1.794-4,4-4S33,46.794,33,49z M29,31c-3.309,0-6-2.691-6-6s2.691-6,6-6s6,2.691,6,6S32.309,31,29,31z M47,41c0,1.103-0.897,2-2,2
s-2-0.897-2-2s0.897-2,2-2S47,39.897,47,41z M49,10c-2.206,0-4-1.794-4-4s1.794-4,4-4s4,1.794,4,4S51.206,10,49,10z"></path></svg></button></div><div id="global-graph-outer"><div id="global-graph-container" data-cfg="{&quot;drag&quot;:true,&quot;zoom&quot;:true,&quot;depth&quot;:-1,&quot;scale&quot;:0.9,&quot;repelForce&quot;:0.5,&quot;centerForce&quot;:0.3,&quot;linkDistance&quot;:30,&quot;fontSize&quot;:0.6,&quot;opacityScale&quot;:1,&quot;showTags&quot;:true,&quot;removeTags&quot;:[],&quot;focusOnHover&quot;:true}"></div></div></div><div class="toc desktop-only"><button type="button" id="toc" class aria-controls="toc-content" aria-expanded="true"><h3>目录</h3><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="fold"><polyline points="6 9 12 15 18 9"></polyline></svg></button><div id="toc-content" class><ul class="overflow"><li class="depth-0"><a href="#firefox" data-for="firefox">Firefox</a></li><li class="depth-1"><a href="#firefox-的概述与特点" data-for="firefox-的概述与特点">Firefox 的概述与特点</a></li><li class="depth-1"><a href="#firefox-与-mozilla-的关系" data-for="firefox-与-mozilla-的关系">Firefox 与 Mozilla 的关系</a></li><li class="depth-0"><a href="#firefox-历史发展" data-for="firefox-历史发展">Firefox 历史发展</a></li><li class="depth-1"><a href="#firefox-的早期发展2002-2010" data-for="firefox-的早期发展2002-2010">Firefox 的早期发展2002-2010</a></li><li class="depth-1"><a href="#firefox-的技术革新与竞争2011-2015" data-for="firefox-的技术革新与竞争2011-2015">Firefox 的技术革新与竞争2011-2015</a></li><li class="depth-1"><a href="#firefox-的现代化演变2016--至今" data-for="firefox-的现代化演变2016--至今">Firefox 的现代化演变2016- 至今)</a></li><li class="depth-0"><a href="#firefox-的架构" data-for="firefox-的架构">Firefox 的架构</a></li><li class="depth-1"><a href="#多进程架构的概述" data-for="多进程架构的概述">多进程架构的概述</a></li><li class="depth-1"><a href="#多进程架构的优缺点" data-for="多进程架构的优缺点">多进程架构的优缺点</a></li><li class="depth-0"><a href="#firefox-的渲染机制" data-for="firefox-的渲染机制">Firefox 的渲染机制</a></li><li class="depth-1"><a href="#从输入-url-到页面渲染的详细过程" data-for="从输入-url-到页面渲染的详细过程">从输入 URL 到页面渲染的详细过程</a></li><li class="depth-1"><a href="#gecko-渲染引擎" data-for="gecko-渲染引擎">Gecko 渲染引擎</a></li><li class="depth-1"><a href="#spidermonkey-javascript-引擎" data-for="spidermonkey-javascript-引擎">SpiderMonkey JavaScript 引擎</a></li><li class="depth-0"><a href="#firefox-的性能优化" data-for="firefox-的性能优化">Firefox 的性能优化</a></li><li class="depth-1"><a href="#页面性能优化" data-for="页面性能优化">页面性能优化</a></li><li class="depth-1"><a href="#网络性能优化" data-for="网络性能优化">网络性能优化</a></li><li class="depth-0"><a href="#firefox-的安全机制" data-for="firefox-的安全机制">Firefox 的安全机制</a></li><li class="depth-1"><a href="#同源策略sop-same-origin-policy" data-for="同源策略sop-same-origin-policy">同源策略SOP, Same-Origin Policy</a></li><li class="depth-1"><a href="#沙盒隔离机制" data-for="沙盒隔离机制">沙盒隔离机制</a></li><li class="depth-1"><a href="#内容安全策略csp-content-security-policy" data-for="内容安全策略csp-content-security-policy">内容安全策略CSP, Content Security Policy</a></li><li class="depth-0"><a href="#firefox-扩展开发" data-for="firefox-扩展开发">Firefox 扩展开发</a></li><li class="depth-1"><a href="#webextensions-api" data-for="webextensions-api">WebExtensions API</a></li><li class="depth-1"><a href="#开发与调试" data-for="开发与调试">开发
</script><script type="module">
let mermaidImport = undefined
document.addEventListener('nav', async () => {
if (document.querySelector("code.mermaid")) {
mermaidImport ||= await import('https://cdnjs.cloudflare.com/ajax/libs/mermaid/10.7.0/mermaid.esm.min.mjs')
const mermaid = mermaidImport.default
const darkMode = document.documentElement.getAttribute('saved-theme') === 'dark'
mermaid.initialize({
startOnLoad: false,
securityLevel: 'loose',
theme: darkMode ? 'dark' : 'default'
})
await mermaid.run({
querySelector: '.mermaid'
})
}
});
</script><script src="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.9/contrib/copy-tex.min.js" type="application/javascript"></script><script src="../../../postscript.js" type="module"></script></html>