427 lines
556 KiB
HTML
427 lines
556 KiB
HTML
|
<!DOCTYPE html>
|
|||
|
<html lang="zh"><head><title>Chrome</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&family=Noto Serif Simplified Chinese:wght@400;700&family=Source Sans Pro:ital,wght@0,400;0,600;1,400;1,600&display=swap"/><meta name="viewport" content="width=device-width, initial-scale=1.0"/><meta property="og:title" content="Chrome"/><meta property="og:description" content="Google Chrome 浏览器自2008年发布以来,以其快速、安全、稳定和简洁的用户界面获得广泛使用。基于开源项目Chromium,Chrome支持多进程架构、扩展程序和跨平台兼容,拥有超过60%的市场份额。它还推动了浏览器技术的发展,如V8引擎、Blink渲染引擎、沙盒安全模型,以及对前沿技术如PWA和WebAssembly的支持。 ..."/><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="Google Chrome 浏览器自2008年发布以来,以其快速、安全、稳定和简洁的用户界面获得广泛使用。基于开源项目Chromium,Chrome支持多进程架构、扩展程序和跨平台兼容,拥有超过60%的市场份额。它还推动了浏览器技术的发展,如V8引擎、Blink渲染引擎、沙盒安全模型,以及对前沿技术如PWA和WebAssembly的支持。 ..."/><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/2.Chrome"><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.5
|
|||
|
<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>Google Chrome 浏览器首次发布于 2008 年 9 月,是由 Google 开发的一款免费网络浏览器。其设计初衷是为了提供更快速、稳定和安全的浏览体验。Chrome 的开发基于开源项目<strong>Chromium</strong>,这不仅保证了开发的透明度和社区的贡献,还促使它成为现代浏览器的技术基石之一。自发布以来,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>
|
|||
|
<ul>
|
|||
|
<li><strong>速度</strong>:Chrome 因其优异的性能和快速的网页加载能力而广受好评。其性能优势主要来自于高效的<strong>V8 JavaScript 引擎</strong>和<strong>Blink 渲染引擎</strong>。V8 引擎能够快速编译和执行 JavaScript 代码,而 Blink 渲染引擎负责页面的布局、渲染和绘制,这二者协同作用使 Chrome 在页面加载速度和响应能力上表现出色。</li>
|
|||
|
<li><strong>简洁的用户界面</strong>:Chrome 以其极简主义的设计风格著称,提供了简洁的用户界面,使用户可以专注于内容本身。Chrome 的设计思路是去除多余的工具栏和按钮,最大化显示网页内容,提升用户的浏览体验。</li>
|
|||
|
<li><strong>多进程架构</strong>:Chrome 率先采用了<strong>多进程架构</strong>,即每个标签页、插件以及渲染进程都独立运行。这种设计极大地提升了浏览器的稳定性和安全性。即使一个标签页崩溃,其他标签页依然可以正常运行,避免了浏览器整体崩溃的情况。此外,独立进程为每个页面提供了隔离,增强了浏览器的安全性,防止恶意网站对系统产生威胁。</li>
|
|||
|
<li><strong>扩展支持</strong>:Chrome 拥有丰富的扩展生态系统。用户可以通过 Chrome Web Store 下载并安装各种扩展程序,扩展程序能够大幅增强浏览器的功能,例如广告拦截、开发者工具、自动填充表单等。Chrome 的扩展系统基于 JavaScript、HTML 和 CSS 等 Web 技术,便于开发者构建并发布。</li>
|
|||
|
<li><strong>跨平台兼容</strong>:Chrome 可以在多种操作系统上运行,包括<strong>Windows</strong>、<strong>macOS</strong>、<strong>Linux</strong>、<strong>Android</strong>和<strong>iOS</strong>,并且提供一致的用户体验。无论是在桌面还是移动端,用户都可以享受同样流畅的浏览体验,这得益于 Chrome 对跨平台兼容性的支持。</li>
|
|||
|
<li><strong>同步功能</strong>:Chrome 允许用户通过 Google 账号实现跨设备的<strong>数据同步</strong>。用户只需登录 Google 账号,便可以同步书签、浏览历史记录、扩展程序和设置等内容,从而无缝衔接桌面和移动设备上的浏览体验。这一功能特别方便频繁在不同设备间切换的用户,提供了极高的便利性。</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>根据多项权威的市场分析报告,Google Chrome 自发布以来迅速占据了全球浏览器市场的主导地位。</strong> 截至目前,Chrome 在桌面和移动端的全球市场份额常年稳居第一,拥有超过 60% 的市场占有率。这一现象得益于 Chrome 持续的技术创新和用户体验的提升。Chrome 不仅在速度、稳定性和安全性方面表现出色,还在功能扩展和跨平台支持等领域提供了极大的便利,使其成为用户的首选浏览器。</p>
|
|||
|
<h3 id="chrome-与-chromium-的关系">Chrome 与 Chromium 的关系<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-与-chromium-的关系" 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="chromium-项目">Chromium 项目<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chromium-项目" 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>Chromium 是 Google 主导的一个开源浏览器项目,Chrome 的开发正是基于此项目。</strong> Chromium 作为开源项目,提供了所有 Chrome 浏览器的核心技术和渲染引擎,但它不包含某些 Google 特有的服务和功能,例如<strong>自动更新</strong>、内置的<strong>Flash 插件</strong>、某些视频编解码器的支持(如 AAC 和 H.264)以及 Chrome 专属的用户数据同步功能。由于 Chromium 是完全开源的,任何开发者都可以基于 Chromium 的代码进行修改和重新发布。</p>
|
|||
|
<h4 id="其他基于-chromium-的浏览器">其他基于 Chromium 的浏览器<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#其他基于-chromium-的浏览器" 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>许多现代浏览器都基于 Chromium 项目进行开发,利用其强大的渲染引擎和底层技术。这些浏览器在保留了 Chromium 的性能和安全特性的同时,根据各自的需求对功能和界面进行了定制。其中较为知名的浏览器包括:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>Microsoft Edge</strong>:在转向 Chromium 内核后,Edge 获得了更好的网页兼容性和性能表现,同时保留了 Microsoft 独特的服务集成(如与 Windows 系统的深度整合)。</li>
|
|||
|
<li><strong>Opera</strong>:Opera 基于 Chromium 开发,但提供了其特有的功能,如内置的广告拦截、VPN 服务和侧边栏快速访问功能。</li>
|
|||
|
<li><strong>Brave</strong>:Brave 主打隐私保护,基于 Chromium 构建,并在默认情况下屏蔽广告和跟踪器,同时引入了其独特的奖励系统(BAT),鼓励用户和内容创作者。</li>
|
|||
|
</ul>
|
|||
|
<p>这种基于 Chromium 的浏览器生态系统的繁荣,进一步验证了 Chromium 项目的开放性和强大的技术基础。尽管这些浏览器在用户体验和功能集成方面各有特色,但它们共享了 Chromium 的核心技术,确保了与现代网页标准的兼容性和良好的性能表现。</p>
|
|||
|
<h2 id="chrome-历史发展">Chrome 历史发展<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-历史发展" 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="chrome-的发布与早期发展2008-2010">Chrome 的发布与早期发展(2008-2010)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的发布与早期发展2008-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="首次发布">首次发布<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>Google Chrome 于 2008 年 9 月推出了第一个测试版,首次发布仅支持 Windows 平台。Chrome 的推出引发了广泛关注,它标志着 Google 进军浏览器市场的开始。与当时主流的浏览器(如 Internet Explorer 和 Firefox)相比,Chrome 的设计哲学是提供<strong>更快</strong>、<strong>更稳定</strong>和<strong>更安全</strong>的浏览体验。Chrome 通过引入先进的<strong>V8 JavaScript 引擎</strong>和<strong>多进程架构</strong>,让其在速度和稳定性方面领先于竞争对手。</p>
|
|||
|
<h4 id="开源项目-chromium">开源项目 Chromium<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#开源项目-chromium" 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>与 Chrome 发布同步,Google 还推出了<strong>Chromium</strong>项目,作为 Chrome 的开源基础。Chromium 为开发者和社区提供了浏览器的核心代码。Google 发布的 Chrome 在 Chromium 的基础上,加入了一些专有组件,如<strong>自动更新机制</strong>和<strong>Adobe Flash 插件支持</strong>,这些是开源版本所不具备的。</p>
|
|||
|
<p>Chrome 的独特架构也为浏览器带来了显著的性能提升,特别是<strong>独立标签页崩溃保护</strong>。通过多进程模型,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>发布后不久,Chrome 的市场占有率快速攀升。其简洁的界面设计、卓越的性能以及与 Google 生态系统的深度集成,吸引了大量用户。短短几个月内,Chrome 成功从一个新兴浏览器发展为一个强有力的竞争者,并在几年内迅速获得了数百万的用户。至 2010 年,Chrome 已经成为全球第三大浏览器,仅次于 Internet Explorer 和 Firefox。</p>
|
|||
|
<h3 id="chrome-的快速迭代与功能扩展2011-2015">Chrome 的快速迭代与功能扩展(2011-2015)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的快速迭代与功能扩展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>2010 年,Chrome 推出了<strong>扩展支持</strong>,允许用户通过安装扩展程序来自定义浏览器的功能。这项功能彻底改变了用户与浏览器的交互方式,开发者也可以基于 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>Chrome 的成功不仅局限于 Windows 平台。2010 年,Google 发布了<strong>macOS</strong>和<strong>Linux</strong>版本,进一步扩大了用户群体。2012 年,Chrome 正式登陆<strong>Android</strong>平台,并迅速成为移动设备上的主流浏览器之一。这标志着 Chrome 进入了移动互联网的新时代,并通过跨设备的数据同步功能,提供了一致且无缝的用户体验。</p>
|
|||
|
<h4 id="chrome-web-store-的发布">Chrome Web Store 的发布<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-web-store-的发布" 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>2011 年,Google 推出了<strong>Chrome Web Store</strong>,一个集中化的扩展市场,用户可以在这里下载和安装扩展、主题以及应用程序。该平台不仅为用户提供了丰富的选择,还推动了开发者社区的发展,使得 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>随着网络应用复杂性的不断提高,Google 持续优化 Chrome 的性能。Chrome 团队在 2011 至 2015 年间对<strong>启动速度</strong>、<strong>内存占用</strong>以及<strong>JavaScript 引擎性能</strong>进行了一系列改进,使其在各大基准测试中长期占据领先地位。尤其是<strong>V8 JavaScript 引擎</strong>的不断优化,使得 Chrome 成为了前端开发者首选的开发与测试平台。</p>
|
|||
|
<h3 id="chrome-的现代化演变2016--至今">Chrome 的现代化演变(2016- 至今)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的现代化演变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="material-design-风格引入">Material Design 风格引入<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#material-design-风格引入" 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>2016 年,Chrome 的界面设计进行了重大更新,正式引入了 Google 的<strong>Material Design</strong>设计语言。这一改动带来了更简洁的视觉风格和更加一致的用户体验。Material Design 的引入不仅优化了 Chrome 的外观,还提升了用户的操作流畅性,使得浏览体验更加直观和友好。</p>
|
|||
|
<h4 id="对-http-的安全改进">对 HTTP 的安全改进<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#对-http-的安全改进" 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>Google 一直致力于提高 Web 的安全性。自 2017 年起,Chrome 开始对<strong>未使用 SSL 加密</strong>的 HTTP 网站标注为“不安全”。这一举措是推动 Web 安全转型的重要一步,促使大量网站转向更安全的<strong>HTTPS 协议</strong>。Chrome 对安全性的不懈追求,加速了整个互联网向加密通信的转变,提升了用户的隐私保护和数据安全。</p>
|
|||
|
<h4 id="逐步淘汰-flash">逐步淘汰 Flash<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#逐步淘汰-flash" 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>Chrome 对<strong>Adobe Flash</strong>的支持逐步减少,并最终于 2020 年完全停止支持。这一决定反映了 Web 技术的演变趋势,Google 希望通过淘汰 Flash,推动更现代化的 Web 标准(如<strong>HTML5</strong>和<strong>WebAssembly</strong>)的应用,提升 Web 的开放性、安全性和性能。</p>
|
|||
|
<h4 id="chrome-devtools-的扩展与强化">Chrome DevTools 的扩展与强化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-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>Chrome 不仅作为用户浏览器表现卓越,作为开发工具也同样功能强大。<strong>Chrome DevTools</strong>随着时间的推移不断扩展,增加了对前端开发者至关重要的功能,如<strong>JavaScript 调试</strong>、<strong>网络请求分析</strong>、<strong>性能监控</strong>以及<strong>渐进式 Web 应用(PWA)</strong> 的调试支持。Chrome 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>
|
|||
|
<p>随着移动互联网的兴起,Chrome 在移动端的表现也愈发重要。Google 通过优化<strong>移动端浏览器的性能</strong>、改进触屏交互以及增强<strong>跨设备同步功能</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>Chrome 通过不断引入新技术和优化现有功能,保持了其在浏览器市场的技术领先地位。例如,<strong>内存管理优化</strong>和<strong>标签页冻结</strong>功能,减少了不活跃标签页的资源占用,大幅提高了整体性能。V8 JavaScript 引擎的持续优化、对<strong>WebAssembly</strong>的支持等,也为现代 Web 应用提供了强大的运行时性能,进一步推动了浏览器在复杂应用场景中的应用。</p>
|
|||
|
<h2 id="chrome-的架构">Chrome 的架构<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的架构" 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>Chrome 的多进程架构设计是其性能、稳定性和安全性的重要基石。</strong> 与传统的单进程浏览器模型不同,Chrome 将不同的浏览器任务分配给多个独立的进程,从而提升了浏览器的稳定性和安全性。具体来说,Chrome 的多进程模型可以划分为以下几类进程:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>浏览器进程</strong>:浏览器进程是整个浏览器的主进程,负责管理用户界面(UI)、网络请求、文件存储以及控制浏览器窗口和标签页的操作。它还处理用户的输入(如点击、键盘输入)并负责协调其他子进程之间的通信。</li>
|
|||
|
<li><strong>渲染进程</strong>:每个标签页都会有一个独立的渲染进程,负责渲染页面内容。渲染进程处理 HTML、CSS 解析、JavaScript 执行和页面布局等任务。为了保证安全,渲染进程通常在<strong>沙盒</strong>中运行,这意味着它被隔离在一个有限的权限环境中,无法直接访问操作系统的关键资源,防止恶意网页或代码对系统造成破坏。</li>
|
|||
|
<li><strong>GPU 进程</strong>:GPU 进程专门负责处理与图形相关的任务,包括页面的图层合成和硬件加速绘制。这使得页面内容能够以更高效的方式呈现,尤其是对于需要大量图形处理的页面(如 3D 图形或动画),GPU 加速能显著提高渲染性能。</li>
|
|||
|
<li><strong>插件进程</strong>:Chrome 为每个插件分配独立的插件进程,确保即使插件崩溃,也不会影响其他标签页或整个浏览器的运行。这种隔离机制同样提高了浏览器的稳定性。</li>
|
|||
|
<li><strong>扩展进程</strong>:Chrome 的扩展运行在独立的扩展进程中,与页面内容隔离。这不仅提高了浏览器的安全性,还能保证扩展不会干扰页面的正常运行。</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>:Chrome 的多进程架构显著提升了浏览器的稳定性。每个标签页、插件和扩展都在各自的进程中运行,因此即使一个标签页崩溃,其他标签页和浏览器本身仍然可以正常工作。此外,独立的插件进程避免了插件崩溃导致整个浏览器崩溃的风险。</li>
|
|||
|
<li><strong>安全性</strong>:Chrome 通过<strong>进程隔离</strong>和<strong>沙盒技术</strong>提高了浏览器的安全性。每个渲染进程在沙盒中运行,这限制了进程对操作系统的访问权限,降低了恶意代码攻击系统的风险。即使某个标签页被恶意攻击,攻击者也难以利用其控制整个系统。</li>
|
|||
|
<li><strong>并行处理</strong>:多进程架构允许 Chrome 更好地利用现代多核 CPU。由于多个进程可以并发执行,Chrome 能够更高效地处理多个标签页的加载、渲染和执行任务,提升浏览器的整体性能。</li>
|
|||
|
</ul>
|
|||
|
<p><strong>缺点</strong></p>
|
|||
|
<ul>
|
|||
|
<li>内存占用较高:由于每个进程都有自己的独立内存空间,多进程架构导致了内存使用的显著增加。尤其是在同时打开多个标签页时,每个标签页分配一个独立的渲染进程会占用更多的内存资源。虽然多进程模型带来了稳定性和安全性,但相对于单进程浏览器,它对系统的内存消耗更大。</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>是 Chrome 实现浏览器安全的重要机制之一。它通过将渲染进程置于受限环境中,减少了恶意网页对系统的潜在威胁。</p>
|
|||
|
<ul>
|
|||
|
<li><strong>渲染进程沙盒</strong>:Chrome 中的渲染进程运行在沙盒中,这意味着即使渲染进程处理恶意网页,也无法直接访问操作系统的敏感资源或文件。沙盒通过限制系统调用、文件访问等权限,保护用户系统免受来自网页的潜在攻击。沙盒机制确保了即使网页中的 JavaScript 或恶意代码试图执行危险操作,这些操作也会被阻止,保证用户系统的安全。</li>
|
|||
|
<li><strong>进程间通信(IPC)</strong>:Chrome 的多进程架构依赖于<strong>IPC(进程间通信)</strong> 机制来实现各进程之间的数据交换。浏览器进程、渲染进程、GPU 进程等通过 IPC 协议进行通信。例如,当用户在浏览器地址栏输入网址时,浏览器进程会将请求传递给渲染进程,渲染进程完成页面加载和渲染后,再通过 IPC 将结果返回。IPC 的设计确保了即使进程之间彼此隔离,它们仍能高效合作。</li>
|
|||
|
</ul>
|
|||
|
<h2 id="chrome-的渲染机制">Chrome 的渲染机制<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的渲染机制" 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 并按下回车键时,浏览器将开始一系列复杂的过程,从网络请求到页面渲染完成。下面是详细的步骤说明:</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>DNS 解析</strong>:浏览器首先通过 DNS(域名系统)将用户输入的域名转换为服务器的 IP 地址。如果该域名对应的 IP 地址已被缓存,浏览器可以直接使用缓存中的结果。否则,浏览器会通过 DNS 服务器查询 IP 地址。</li>
|
|||
|
<li><strong>建立连接</strong>:获取 IP 地址后,浏览器与服务器建立 TCP 连接。如果是 HTTPS 请求,还需进行<strong>TLS 握手</strong>来加密通信。通常,TCP 连接会通过三次握手来建立。</li>
|
|||
|
<li><strong>发送 HTTP 请求</strong>:连接建立后,浏览器会发起 HTTP 请求,请求的内容包括 HTML 文档及其引用的资源(如 CSS、JavaScript、图片等)。</li>
|
|||
|
<li><strong>接收响应</strong>:服务器处理请求后,返回 HTTP 响应,其中包含了请求的 HTML 文档和其他资源的 URL。浏览器根据这些资源的类型进一步请求它们,以便完成页面渲染。</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>浏览器接收到 HTML 文档和其他资源后,开始进入渲染流程,即将网络传输的字节转换为屏幕上可见的内容。该过程包括以下几个阶段:</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 元素的样式属性。</li>
|
|||
|
<li><strong>合成渲染树</strong>:浏览器将<strong>DOM 树</strong>和<strong>CSSOM 树</strong>结合起来生成<strong>渲染树</strong>(Render Tree)。渲染树包含页面中的所有可见元素,并应用其样式。与 DOM 树不同,渲染树只包含需要显示的内容,诸如 <code><head></code> 标签或带有 <code>display: none</code> 样式的元素不会被包括在内。</li>
|
|||
|
<li><strong>布局(Layout)</strong>:渲染树生成后,浏览器开始进行<strong>布局</strong>计算,也称为 ” 回流 “。在此步骤中,浏览器计算每个元素的具体大小和位置。布局过程基于 CSS 盒模型,通过对渲染树进行遍历来确定元素的几何属性,如宽度、高度、相对位置等。</li>
|
|||
|
<li><strong>绘制(Painting)</strong>:完成布局后,浏览器将<strong>绘制</strong>页面的内容。绘制包括文本、颜色、背景、边框、阴影等各类视觉样式。此时,渲染树中的元素被绘制成位图。</li>
|
|||
|
<li><strong>合成与图层管理(Compositing)</strong>:页面中可能有多个图层(如浮动的元素、动画等),这些图层需要由<strong>合成器线程</strong>进行合成处理。合成器将这些图层组合成最终的页面视图,并通过 GPU 进行硬件加速渲染,从而提高渲染性能,尤其是复杂页面的绘制效率。</li>
|
|||
|
</ul>
|
|||
|
<h3 id="chrome-的-blink-渲染引擎">Chrome 的 Blink 渲染引擎<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的-blink-渲染引擎" 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="blink-引擎概述">Blink 引擎概述<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#blink-引擎概述" 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>Blink</strong>是 Google Chrome 使用的渲染引擎,它是从 WebKit 渲染引擎的一个分支,专门用于处理 HTML、CSS、JavaScript 等 Web 内容,并将其转化为屏幕上可见的页面。Blink 的高效性和现代化设计使得 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>
|
|||
|
<ul>
|
|||
|
<li><strong>渲染树生成</strong>:Blink 通过解析 DOM 树和 CSSOM 树来生成<strong>渲染树</strong>。渲染树只包含可见的页面元素及其样式,因此相比 DOM 树,渲染树结构更加精简且高效。</li>
|
|||
|
<li><strong>渲染树的作用</strong>:渲染树是后续布局和绘制过程的基础。它提供了每个可见元素的样式和层次关系,供浏览器在布局计算和最终绘制时使用。Blink 通过对渲染树的处理,将页面内容准确地呈现给用户。</li>
|
|||
|
</ul>
|
|||
|
<h4 id="合成器线程compositor-thread">合成器线程(Compositor Thread)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#合成器线程compositor-thread" 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>为了提高渲染性能,Blink 引入了<strong>合成器线程</strong>。合成器线程专门处理图层的合成任务,避免主线程(负责执行 JavaScript 和处理页面逻辑)因繁重的渲染任务而被阻塞。合成器线程通过协调各个图层的绘制,确保页面即使在存在复杂动画或大量图层时,仍能流畅地进行渲染。</p>
|
|||
|
<h3 id="v8-javascript-引擎">V8 JavaScript 引擎<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#v8-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>
|
|||
|
<p><strong>V8</strong>是 Chrome 中的 JavaScript 引擎,负责将 JavaScript 代码转换为机器码并执行。作为一款高性能引擎,V8 在 JavaScript 的执行效率、内存管理和性能优化上有许多先进的设计。</p>
|
|||
|
<h4 id="即时编译jitjust-in-time">即时编译(JIT,Just-in-Time)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#即时编译jitjust-in-time" 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>V8 采用了<strong>即时编译</strong>(JIT)技术,通过将 JavaScript 代码在执行时即时编译为机器码,避免了传统解释器逐行解释执行代码的低效问题。JIT 编译大大提升了 JavaScript 的执行速度,使得现代 Web 应用中的 JavaScript 代码能够在浏览器中快速运行。</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>V8 通过<strong>分代式垃圾回收</strong>(Generational Garbage Collection)来管理内存。分代垃圾回收将内存中的对象分为“新生代”和“老生代”两个区域。新生代对象是刚刚创建的对象,回收频率较高,而老生代对象则是存活时间较长的对象。通过对新生代对象进行快速清理,并采用更复杂的策略回收老生代对象,V8 能够有效降低内存泄漏,并保证应用的平稳运行。</p>
|
|||
|
<h2 id="chrome-的性能优化">Chrome 的性能优化<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的性能优化" 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>优化 Chrome 浏览器中的页面性能和网络性能是提升用户体验和提高应用响应速度的关键。在现代 Web 开发中,合理管理关键渲染路径、减少不必要的 DOM 操作、以及充分利用网络协议和缓存机制,能够显著提高 Web 应用的整体表现。</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>
|
|||
|
<p><strong>页面性能优化的核心在于减少渲染的阻塞、减少 DOM 操作的开销,以及最大限度地优化资源加载和渲染流程。</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><strong>关键渲染路径</strong>(Critical Rendering Path)是浏览器从获取 HTML 文件到将页面内容呈现在屏幕上的一系列步骤。为了加快页面渲染速度,开发者应尽量减少阻塞渲染的关键资源,并异步加载非必要的资源。</p>
|
|||
|
<ul>
|
|||
|
<li><strong>减少阻塞资源</strong>:CSS 和 JavaScript 文件会阻塞页面的渲染,尤其是位于页面头部的资源。为了优化关键渲染路径,可以使用 <code><link rel="preload"></code> 预加载关键资源,减少首次渲染时间。</li>
|
|||
|
<li><strong>异步加载 JavaScript</strong>:使用 <code>async</code> 或 <code>defer</code> 属性加载 JavaScript 文件。<code>async</code> 属性允许脚本并行下载并尽快执行,而 <code>defer</code> 则在 HTML 解析完成后才执行脚本,避免阻塞页面的渲染。</li>
|
|||
|
</ul>
|
|||
|
<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;"><</span><span style="--shiki-light:#22863A;--shiki-dark:#85E89D;">script</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> src</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"script.js"</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> async</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></</span><span style="--shiki-light:#22863A;--shiki-dark:#85E89D;">script</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:#22863A;--shiki-dark:#85E89D;">script</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> src</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"deferred.js"</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> defer</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></</span><span style="--shiki-light:#22863A;--shiki-dark:#85E89D;">script</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></span></span></code></pre></figure>
|
|||
|
<ul>
|
|||
|
<li><strong>CSS 优化</strong>:将关键的 CSS 直接内联到 HTML 文件中,减少渲染的阻塞时间。对于非关键 CSS 文件,使用 <code>media</code> 属性延迟其加载。</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;"><</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;">"stylesheet"</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;">"style.css"</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> media</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"print"</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> onload</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">this</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">.</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">media</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'all'"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></span></span></code></pre></figure>
|
|||
|
<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>重绘(Repaint)</strong>:发生在元素的视觉外观发生改变时,例如颜色、背景或阴影变化,但不影响其布局。重绘虽然比回流开销小,但仍然影响性能。</li>
|
|||
|
<li><strong>回流(Reflow)</strong>:回流是布局的重新计算,发生在元素的大小、位置或结构发生改变时,需要重新计算渲染树。回流比重绘开销大,频繁的回流会显著影响性能。</li>
|
|||
|
</ul>
|
|||
|
<p>优化策略:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>减少 DOM 操作</strong>:频繁修改 DOM 会引发回流。应尽量避免多次操作 DOM,代之以<strong>批量操作</strong>。例如,使用 <code>DocumentFragment</code> 来集中处理多次 DOM 修改,最后一次性插入页面。</li>
|
|||
|
<li><strong>避免触发回流属性</strong>:访问或修改像 <code>offsetWidth</code>、<code>offsetHeight</code>、<code>scrollTop</code> 等属性会强制触发浏览器的回流。将这些操作集中到一个步骤中,避免在同一循环中反复读取和修改布局属性。</li>
|
|||
|
<li><strong>CSS 优化</strong>:将影响性能的动画限制在 <code>transform</code> 和 <code>opacity</code> 上,这样可以避免触发回流。</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>网络优化是页面快速加载的另一个重要环节,优化网络请求的数量和质量能够显著加快页面的初次渲染。</p>
|
|||
|
<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>
|
|||
|
<ul>
|
|||
|
<li><strong>HTTP/2</strong>:通过<strong>多路复用</strong>技术,HTTP/2 允许多个请求同时通过一个 TCP 连接传输,减少了连接的建立和关闭时间。同时,HTTP/2 支持<strong>头部压缩</strong>,通过减少冗余的 HTTP 请求头部信息,进一步减少了网络传输的开销。</li>
|
|||
|
<li><strong>HTTP/3</strong>:基于 UDP 协议的 HTTP/3,利用<strong>QUIC</strong>协议减少了 TCP 的握手延迟,并且可以在网络不稳定时更加高效地恢复数据传输,进一步提升了网站的加载速度。</li>
|
|||
|
</ul>
|
|||
|
<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><strong>CDN(内容分发网络)</strong>:通过使用 CDN,将静态资源分布到多个地理位置的服务器上,确保用户从最近的服务器获取资源,减少传输延迟。CDN 还能有效减轻源服务器的负担,提高整体响应速度。</li>
|
|||
|
<li><strong>缓存策略</strong>:合理利用浏览器缓存能够极大提升页面加载性能。通过配置 <code>Cache-Control</code> 和 <code>ETag</code> 等 HTTP 头部,可以控制资源的缓存时间和验证机制,避免重复下载未更改的资源。
|
|||
|
<ul>
|
|||
|
<li><strong><code>Cache-Control</code></strong>:设置资源的缓存有效期,例如使用 <code>max-age</code> 指定资源在多少秒内有效。</li>
|
|||
|
<li><strong><code>ETag</code></strong>:利用 ETag 头部标识资源的版本,当资源没有变化时,服务器可以返回 304 状态码,告知浏览器使用本地缓存,减少网络带宽的消耗。</li>
|
|||
|
</ul>
|
|||
|
</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;">Cache-Control: max-age=31536000, public</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">ETag: "abc123"</span></span></code></pre></figure>
|
|||
|
<h4 id="lazy-load-技术">Lazy Load 技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#lazy-load-技术" 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>**懒加载(Lazy Loading)**是优化初次加载时的资源利用效率的重要技术,尤其适用于图片和视频等较大资源。懒加载技术会延迟加载那些在页面初始化时不需要立即显示的资源,直到用户滚动到这些资源的位置时才加载它们。</p>
|
|||
|
<ul>
|
|||
|
<li><strong>图片懒加载</strong>:在现代浏览器中,可以通过为 <code><img></code> 标签添加 <code>loading="lazy"</code> 属性,轻松实现图片的懒加载。</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;"><</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;">"large-image.jpg"</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;">"lazy"</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;">"Lazy loaded image"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">></span></span></code></pre></figure>
|
|||
|
<ul>
|
|||
|
<li><strong>视频懒加载</strong>:类似的,视频也可以使用懒加载技术,只有当用户即将观看时才加载视频内容。</li>
|
|||
|
</ul>
|
|||
|
<p>通过这些技术,页面的初始加载时间和数据传输量都能够显著减少,从而提升页面的响应速度。</p>
|
|||
|
<h2 id="chrome-浏览器的安全机制">Chrome 浏览器的安全机制<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-浏览器的安全机制" 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>Chrome 浏览器的安全机制旨在保护用户的数据和隐私,防止恶意网站或代码对用户系统造成危害。它通过多种技术手段确保网页和扩展的安全性,包括同源策略、沙盒机制和内容安全策略(CSP)。</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 安全模型的核心之一,它限制了不同来源(origin)之间的文档和脚本如何进行交互。浏览器将每个网页的资源视为具有特定的来源,只有在同源的情况下,页面之间的脚本才能进行互相访问。这种机制极大地减少了潜在的安全威胁,例如跨站脚本(XSS)和跨站请求伪造(CSRF)。</p>
|
|||
|
<ul>
|
|||
|
<li><strong>来源的定义</strong>:同源意味着两个 URL 具有相同的<strong>协议</strong>、<strong>域名</strong>和<strong>端口</strong>。例如,<code>https://example.com:443</code> 与 <code>https://example.com</code> 视为同源,但 <code>https://example.com</code> 与 <code>http://example.com</code>、<code>https://sub.example.com</code> 则被视为不同源。</li>
|
|||
|
</ul>
|
|||
|
<p>通过同源策略,Chrome 可以有效防止恶意网站通过脚本读取、修改或操纵其他站点的敏感信息,从而提升用户数据的安全性。</p>
|
|||
|
<h4 id="跨源资源共享cors-cross-origin-resource-sharing">跨源资源共享(CORS, Cross-Origin Resource Sharing)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#跨源资源共享cors-cross-origin-resource-sharing" 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>(CORS)机制应运而生。CORS 允许服务器通过 HTTP 头部信息明确声明哪些外部来源可以访问其资源,进而控制跨域请求的安全性。</p>
|
|||
|
<p>CORS 的工作机制包括:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>预检请求</strong>:当浏览器发送跨域请求时,首先会通过 <code>OPTIONS</code> 方法发出<strong>预检请求</strong>,询问服务器是否允许该跨域访问。服务器通过响应头中的 <code>Access-Control-Allow-Origin</code>、<code>Access-Control-Allow-Methods</code> 等字段来决定是否允许请求。</li>
|
|||
|
<li><strong>跨域响应头</strong>:服务器可以通过设置 <code>Access-Control-Allow-Origin</code> 头部,指定允许访问资源的来源。设置为 <code>*</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:#22863A;--shiki-dark:#85E89D;">Access-Control-Allow-Origin</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">:</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> https://example.com</span></span></code></pre></figure>
|
|||
|
<p>通过 CORS,Chrome 浏览器能够灵活处理跨域资源请求,确保在安全框架下允许合法的跨域数据交互。</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>Chrome 的<strong>沙盒机制</strong>是其安全架构的核心之一。<strong>沙盒</strong>将每个标签页、插件或扩展的渲染进程与操作系统隔离开来,限制其对系统资源的访问。这意味着,即使某个网页包含恶意代码,该代码也无法直接访问或修改用户的文件、网络连接或其他敏感资源。</p>
|
|||
|
<ul>
|
|||
|
<li>沙盒隔离的优点:
|
|||
|
<ul>
|
|||
|
<li><strong>限制访问权限</strong>:沙盒通过减少进程的权限,确保恶意网站或代码只能在受控的环境中运行,无法对系统核心组件造成威胁。</li>
|
|||
|
<li><strong>安全分区</strong>:每个标签页的渲染进程都在沙盒中独立运行,如果一个标签页崩溃或受到攻击,其他标签页不会受到影响,保障了浏览器的稳定性和安全性。</li>
|
|||
|
</ul>
|
|||
|
</li>
|
|||
|
</ul>
|
|||
|
<p>这种基于沙盒的隔离策略,不仅防止了浏览器内恶意脚本的横向移动,还阻止了潜在攻击对操作系统和用户数据的直接访问。</p>
|
|||
|
<h4 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></h4>
|
|||
|
<p><strong>内容安全策略</strong>(Content Security Policy, CSP)是 Chrome 中用于防止常见 Web 攻击(如 XSS)的关键机制。CSP 通过定义允许网页加载的资源类型和来源,帮助开发者控制网页内容的来源,防止恶意脚本或未经授权的资源注入页面。</p>
|
|||
|
<ul>
|
|||
|
<li>CSP 的作用:
|
|||
|
<ul>
|
|||
|
<li><strong>防止 XSS 攻击</strong>:通过 CSP,开发者可以禁止网页加载未经授权的脚本,从而阻止恶意脚本通过漏洞注入到网页中执行。</li>
|
|||
|
<li><strong>限制资源加载</strong>:CSP 允许开发者指定页面能够加载的资源来源(如脚本、样式、图像等),从而限制外部资源对页面的影响。例如,开发者可以使用 CSP 规定只有从可信的域名加载 JavaScript 文件。</li>
|
|||
|
</ul>
|
|||
|
</li>
|
|||
|
</ul>
|
|||
|
<p>CSP 示例:</p>
|
|||
|
<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:#22863A;--shiki-dark:#85E89D;">Content-Security-Policy</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">:</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> script-src 'self' https://trusted.cdn.com; object-src 'none';</span></span></code></pre></figure>
|
|||
|
<p>该策略仅允许从当前来源(<code>self</code>)和受信任的 CDN(<code>https://trusted.cdn.com</code>)加载脚本,并禁止页面加载任何插件或嵌入式对象(<code>object-src 'none'</code>)。通过这种方式,CSP 可以极大地减少攻击面,防止常见的跨站脚本攻击。</p>
|
|||
|
<h2 id="chrome-扩展开发">Chrome 扩展开发<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-扩展开发" 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="chrome-扩展的核心概念">Chrome 扩展的核心概念<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-扩展的核心概念" 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>Chrome 扩展是用于增强浏览器功能的模块,允许用户根据需求自定义浏览体验。开发 Chrome 扩展需要遵循特定的结构和 API 规范。以下是 Chrome 扩展的核心概念和主要组成部分:</p>
|
|||
|
<h4 id="manifestjson-文件"><code>manifest.json</code> 文件<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>**<code>manifest.json</code>**是每个 Chrome 扩展的核心配置文件,负责定义扩展的基本信息、权限、功能以及相关资源。该文件的内容决定了扩展的行为方式以及可以访问的浏览器功能。主要字段包括:</p>
|
|||
|
<ul>
|
|||
|
<li><strong><code>name</code></strong>:扩展的名称。</li>
|
|||
|
<li><strong><code>version</code></strong>:扩展的版本号。</li>
|
|||
|
<li><strong><code>manifest_version</code></strong>:Chrome 扩展的规范版本(目前为 3)。</li>
|
|||
|
<li><strong><code>permissions</code></strong>:扩展所需的权限,如访问特定网站、读取浏览历史、操作标签页等。</li>
|
|||
|
<li><strong><code>background</code></strong>:定义扩展的<strong>背景脚本</strong>,可以长期运行并处理后台任务。</li>
|
|||
|
<li><strong><code>content_scripts</code></strong>:定义<strong>内容脚本</strong>,它们能够注入到网页中,操纵 DOM 结构。</li>
|
|||
|
<li><strong><code>icons</code></strong>:扩展所使用的图标。</li>
|
|||
|
</ul>
|
|||
|
<p>示例:</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;"> "name"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"My Chrome Extension"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "version"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"1.0"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "manifest_version"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">3</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "permissions"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"tabs"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"storage"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">],</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "background"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: {</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "service_worker"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"background.js"</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;"> "content_scripts"</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;"> "matches"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"https://*.example.com/*"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">],</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "js"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"content.js"</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:#005CC5;--shiki-dark:#79B8FF;"> "icons"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: {</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "16"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"icon16.png"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "48"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"icon48.png"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "128"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"icon128.png"</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>
|
|||
|
<h4 id="背景脚本background-scripts">背景脚本(Background Scripts)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#背景脚本background-scripts" 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>负责管理扩展的长时间运行任务,通常用于事件监听、消息传递和执行特定的操作。背景脚本在后台运行,不会直接与网页交互,它们可以通过<strong>chrome API</strong>与浏览器进行通信。例如,它可以监听标签页的创建、关闭或消息传递。</p>
|
|||
|
<p>在 Manifest Version 3 中,背景脚本被<strong>Service Workers</strong>取代,进一步增强了扩展的性能和安全性,确保扩展在不活动时不占用系统资源。</p>
|
|||
|
<p>示例:</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;">=></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;">"Extension installed"</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:#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 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;"> 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;"> "complete"</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;">"Tab updated:"</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>
|
|||
|
<h4 id="内容脚本content-scripts">内容脚本(Content Scripts)<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#内容脚本content-scripts" 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>运行在特定网页的上下文中,允许开发者直接操作网页的 DOM 结构。它们可以修改页面的内容、插入样式或脚本,但不能直接访问 Chrome 扩展的 API。为了与背景脚本或扩展其他部分通信,内容脚本可以使用<strong>消息传递机制</strong>。</p>
|
|||
|
<p>内容脚本与页面的 JavaScript 环境是分离的,虽然它们能够操作 DOM,但无法直接访问页面的全局变量或函数。</p>
|
|||
|
<p>示例:</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;">document.body.style.backgroundColor </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> "yellow"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">;</span></span></code></pre></figure>
|
|||
|
<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>为了防止恶意扩展滥用浏览器功能,Chrome 扩展的安全模型设计了严格的权限和跨域请求限制。开发者必须声明扩展所需的所有权限,并且 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>每个 Chrome 扩展必须在 <code>manifest.json</code> 中明确声明其所需的权限,如访问特定网站的权限、读取或修改浏览历史的权限、操作 Cookie 或标签页的权限等。Chrome 通过这种机制限制扩展的访问范围,以减少潜在的安全威胁。</p>
|
|||
|
<p>常见权限示例:</p>
|
|||
|
<ul>
|
|||
|
<li><code>"tabs"</code>:允许扩展访问和操作浏览器的标签页。</li>
|
|||
|
<li><code>"cookies"</code>:访问和修改网站的 Cookie。</li>
|
|||
|
<li><code>"storage"</code>:使用 Chrome 的本地存储功能。</li>
|
|||
|
<li><code>"activeTab"</code>:允许扩展与当前活动的标签页交互。</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>Chrome 扩展可以通过 <code>chrome.extension</code> API<strong>执行跨域请求,而无需遵守浏览器通常的</strong>同源策略**(Same-Origin Policy)。然而,为了保证安全,开发者必须在 <code>manifest.json</code> 中声明明确的权限,允许扩展访问特定域名。这种设计确保扩展不会随意访问或篡改用户的数据。</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;"> "permissions"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: [</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> "https://api.example.com/"</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>通过这种方式,用户可以清楚地了解扩展的访问权限,防止扩展未经许可访问敏感数据。</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>
|
|||
|
<p>Chrome 扩展的开发过程中,Chrome 浏览器提供了丰富的调试工具,帮助开发者在不同的环境下进行测试和调试。</p>
|
|||
|
<h4 id="chrome-devtools">Chrome DevTools<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-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>Chrome DevTools 不仅可以用于调试网页,还支持对 Chrome 扩展进行调试。开发者可以通过以下功能调试扩展:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>调试内容脚本</strong>:通过“Sources”选项卡,调试注入到网页中的内容脚本,设置断点、查看 DOM 结构或检查网络请求。</li>
|
|||
|
<li><strong>调试背景脚本</strong>:在“Background page”中,开发者可以查看并调试背景脚本的运行状态,监控事件、网络请求和消息传递行为。</li>
|
|||
|
<li><strong>消息传递调试</strong>:通过检查“Console”选项卡中的日志信息,分析内容脚本与背景脚本之间的通信是否正常。</li>
|
|||
|
</ul>
|
|||
|
<h4 id="发布到-chrome-web-store">发布到 Chrome Web Store<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#发布到-chrome-web-store" 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>Chrome Web Store</strong>。发布步骤如下:</p>
|
|||
|
<ol>
|
|||
|
<li><strong>打包扩展</strong>:在 Chrome 的扩展管理页面中,将开发完成的扩展打包为 <code>.zip</code> 文件。</li>
|
|||
|
<li><strong>注册开发者账号</strong>:开发者需拥有 Google 账号并注册成为 Chrome Web Store 的开发者。</li>
|
|||
|
<li><strong>上传扩展</strong>:通过 Chrome Web Store 管理后台上传打包的扩展文件。</li>
|
|||
|
<li><strong>填写扩展信息</strong>:包括扩展名称、描述、版本信息、权限说明、截图等。</li>
|
|||
|
<li><strong>审核和发布</strong>:Chrome Web Store 会对扩展进行安全审核,确保其符合安全规范和隐私政策。审核通过后,用户可以从 Chrome Web Store 下载安装扩展。</li>
|
|||
|
</ol>
|
|||
|
<h2 id="chrome-的前沿技术">Chrome 的前沿技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#chrome-的前沿技术" 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>Chrome 浏览器始终处于推动 Web 技术发展的前沿,不断引入新的技术来增强 Web 应用的功能和性能。以下是两项重要的前沿技术:<strong>渐进式 Web 应用(PWA)*<em>和*</em>WebAssembly(WASM)</strong>。</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 应用模型。PWA 可以在网络不稳定的情况下正常运行,并且能够像原生应用一样被安装到用户设备上,提供离线功能、推送通知和快捷启动等特性。</p>
|
|||
|
<h4 id="pwa-的核心技术">PWA 的核心技术<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#pwa-的核心技术" 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>Service Workers</strong>:<strong>Service Workers</strong>是 PWA 的核心技术,运行在浏览器的后台,独立于网页本身。它能够拦截网络请求,缓存静态资源,从而实现离线访问。通过 Service Workers,PWA 可以在没有网络连接时继续工作,提供类似原生应用的用户体验。</p>
|
|||
|
<p>另一个关键功能是<strong>推送通知</strong>。即使应用未被打开,Service Workers 也可以通过服务器推送消息,提供消息通知功能。此外,Service Workers 还可以控制更新策略,确保应用始终保持最新版本。</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:#6A737D;--shiki-dark:#6A737D;">// 注册 Service Worker</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">if</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> (</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'serviceWorker'</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> in</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> navigator) {</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> navigator.serviceWorker.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">register</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'/sw.js'</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;">registration</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;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'Service Worker registered with scope:'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, registration.scope);</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }).</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">catch</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">error</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;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">'Service Worker registration failed:'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, error);</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>Manifest 文件</strong>:<strong>Web App Manifest</strong>是一个 JSON 文件,定义了 PWA 的启动行为、图标、显示模式(如全屏、固定窗口等),使 Web 应用在外观和使用上更接近原生应用。通过 Manifest 文件,用户可以将 PWA 应用安装到主屏幕,并通过自定义图标和启动界面提供一致的用户体验。</p>
|
|||
|
<p>示例 <code>manifest.json</code> 文件:</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;"> "name"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"My PWA"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "short_name"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"PWA"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "start_url"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><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:#005CC5;--shiki-dark:#79B8FF;"> "icons"</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;"> "src"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"/images/icon-192.png"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "sizes"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"192x192"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "type"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"image/png"</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;"> "src"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"/images/icon-512.png"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "sizes"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"512x512"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "type"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"image/png"</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;"> "background_color"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"#ffffff"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> "display"</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">"standalone"</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">}</span></span></code></pre></figure>
|
|||
|
</li>
|
|||
|
</ul>
|
|||
|
<h4 id="pwa-在-chrome-中的支持与调试">PWA 在 Chrome 中的支持与调试<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#pwa-在-chrome-中的支持与调试" 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>Chrome 对 PWA 提供了全面的支持,并且可以通过<strong>Chrome DevTools</strong>对 PWA 的功能进行调试:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>离线缓存调试</strong>:在 Chrome DevTools 的 “Application” 面板中,开发者可以查看和管理 Service Workers 的缓存状态,查看哪些资源被缓存,以及何时清理缓存。</li>
|
|||
|
<li><strong>推送通知调试</strong>:DevTools 允许调试 PWA 的推送通知行为,查看消息是否成功推送,并在控制台模拟推送事件。</li>
|
|||
|
<li><strong>Manifest 文件调试</strong>:通过 DevTools 的 “Application” 面板,开发者可以检查 PWA 的 Manifest 文件配置,确保应用图标、启动 URL 等内容符合预期。</li>
|
|||
|
</ul>
|
|||
|
<h3 id="webassemblywasm">WebAssembly(WASM)<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>WebAssembly</strong>(WASM)是一种基于字节码的编程语言,它允许开发者在浏览器中运行接近原生性能的代码。WASM 的出现使得高性能计算和复杂的应用场景(如游戏、图像处理、数据分析等)可以在浏览器中高效运行。</p>
|
|||
|
<h4 id="webassembly-简介">WebAssembly 简介<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#webassembly-简介" 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 是一种<strong>平台无关的二进制格式</strong>,通过编译其他高级语言(如 C、C++、Rust)生成字节码,在浏览器中执行这些代码时能够接近原生应用的性能。WASM 的设计目标是让 Web 应用能够高效地处理复杂计算任务,如 3D 图形、音频处理和加密等,这些通常是 JavaScript 难以胜任的场景。</p>
|
|||
|
<p>WebAssembly 的主要优点包括:</p>
|
|||
|
<ul>
|
|||
|
<li><strong>高性能</strong>:相比于 JavaScript,WASM 以二进制形式传输和执行,具有更快的解析速度和更高效的运行性能。</li>
|
|||
|
<li><strong>跨平台</strong>:WASM 是跨浏览器、跨平台的,Chrome、Firefox、Edge、Safari 等主流浏览器都支持运行 WASM 模块。</li>
|
|||
|
<li><strong>语言无关性</strong>:WebAssembly 不依赖于某一种编程语言,开发者可以用多种高级语言编写代码并编译为 WASM。</li>
|
|||
|
</ul>
|
|||
|
<h4 id="与-javascript-互操作">与 JavaScript 互操作<a role="anchor" aria-hidden="true" tabindex="-1" data-no-popover="true" href="#与-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></h4>
|
|||
|
<p>WebAssembly 并非要完全取代 JavaScript,而是与其互补。开发者可以在 JavaScript 中<strong>调用 WASM 模块</strong>,同时利用 JavaScript 的灵活性和 WASM 的高效计算能力,结合两者的优势构建复杂的 Web 应用。</p>
|
|||
|
<p>下面是一个基本的 WASM 和 JavaScript 互操作示例:</p>
|
|||
|
<ol>
|
|||
|
<li>
|
|||
|
<p>编译 C 代码为 WASM: 假设我们有一个 C 函数 <code>add</code>,将其编译为 WASM 模块。</p>
|
|||
|
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="c" data-theme="github-light github-dark"><code data-language="c" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// add.c</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">int</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> add</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">int</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;"> a</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">int</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;"> b</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;"> a </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">+</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> b;</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">}</span></span></code></pre></figure>
|
|||
|
<p>使用 <code>emscripten</code> 工具链将 C 代码编译为 WebAssembly:</p>
|
|||
|
<figure data-rehype-pretty-code-figure><pre tabindex="0" data-language="shell" data-theme="github-light github-dark"><code data-language="shell" data-theme="github-light github-dark" style="display:grid;"><span data-line><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">emcc</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> add.c</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> -s</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> WASM=</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">1</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> -o</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> add.wasm</span></span></code></pre></figure>
|
|||
|
</li>
|
|||
|
<li>
|
|||
|
<p>在 JavaScript 中加载和调用 WASM 模块:</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:#D73A49;--shiki-dark:#F97583;">const</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> importObject</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;"> env: {</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // 可以定义一些供WASM使用的全局变量或函数</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;">WebAssembly.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">instantiateStreaming</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><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;">'add.wasm'</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">), importObject)</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;">obj</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;"> const</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> add</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> =</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.instance.exports.add;</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;">"Result of 3 + 4 ="</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </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;">3</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">4</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">)); </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 输出:Result of 3 + 4 = 7</span></span>
|
|||
|
<span data-line><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> });</span></span></code></pre></figure>
|
|||
|
</li>
|
|||
|
</ol>
|
|||
|
<p>在这个示例中,WASM 模块定义了一个 <code>add</code> 函数,并通过 JavaScript 进行调用。WebAssembly 模块可以高效执行数值运算、处理复杂算法,从而显著提升应用的性能。</p></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="{"drag":true,"zoom":true,"depth":1,"scale":1.1,"repelForce":0.5,"centerForce":0.3,"linkDistance":30,"fontSize":0.6,"opacityScale":1,"showTags":true,"removeTags":[],"focusOnHover":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="{"drag":true,"zoom":true,"depth":-1,"scale":0.9,"repelForce":0.5,"centerForce":0.3,"linkDistance":30,"fontSize":0.6,"opacityScale":1,"showTags":true,"removeTags":[],"focusOnHover":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="#chrome" data-for="chrome">Chrome</a></li><li class="depth-1"><a href="#概述与特点" data-for="概述与特点">概述与特点</a></li><li class="depth-1"><a href="#chrome-与-chromium-的关系" data-for="chrome-与-chromium-的关系">Chrome 与 Chromium 的关系</a></li><li class="depth-0"><a href="#chrome-历史发展" data-for="chrome-历史发展">Chrome 历史发展</a></li><li class="depth-1"><a href="#chrome-的发布与早期发展2008-2010" data-for="chrome-的发布与早期发展2008-2010">Chrome 的发布与早期发展(2008-2010)</a></li><li class="depth-1"><a href="#chrome-的快速迭代与功能扩展2011-2015" data-for="chrome-的快速迭代与功能扩展2011-2015">Chrome 的快速迭代与功能扩展(2011-2015)</a></li><li class="depth-1"><a href="#chrome-的现代化演变2016--至今" data-for="chrome-的现代化演变2016--至今">Chrome 的现代化演变(2016- 至今)</a></li><li class="depth-0"><a href="#chrome-的架构" data-for="chrome-的架构">Chrome 的架构</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-1"><a href="#沙盒安全模型" data-for="沙盒安全模型">沙盒安全模型</a></li><li class="depth-0"><a href="#chrome-的渲染机制" data-for="chrome-的渲染机制">Chrome 的渲染机制</a></li><li class="depth-1"><a href="#从输入-url-到页面渲染的详细过程" data-for="从输入-url-到页面渲染的详细过程">从输入 URL 到页面渲染的详细过程</a></li><li class="depth-1"><a href="#chrome-的-blink-渲染引擎" data-for="chrome-的-blink-渲染引擎">Chrome 的 Blink 渲染引擎</a></li><li class="depth-1"><a href="#v8-javascript-引擎" data-for="v8-javascript-引擎">V8 JavaScript 引擎</a></li><li class="depth-0"><a href="#chrome-的性能优化" data-for="chrome-的性能优化">Chrome 的性能优化</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="#chrome-浏览器的安全机制" data-for="chrome-浏览器的安全机制">Chrome 浏览器的安全机制</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-0"><a href="#chrome-扩展开发" data-for="chrome-扩展开发">Chrome 扩展开发</a></li><li class="depth-1"><a href="#chrome-扩展的核心概念" data-for="chrome-扩展的核心概念">Chrome 扩展的核心概念</a></li><li class="depth-1"><a href="#扩展的安全模型" data-for="扩展的安全模型"><EFBFBD>
|
|||
|
</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>
|