外观
使用 Vue 的多种方式
在 Web 的世界中从来就没有可以适配所有场景、解决所有问题的银弹。正因如此,Vue 被设计成一个灵活的、可以渐进式集成的框架。根据使用场景的不同需要,相应地有多种不同的方式来使用 Vue,以此在技术栈复杂度、开发体验和性能表现间取得最佳平衡。
独立脚本
Vue 可以作为独立的脚本文件使用,无需构建步骤!如果你有一个后端框架,并且它已经渲染了大部分的 HTML,或者你的前端逻辑并不复杂,不需要构建步骤,这会是你集成 Vue 最容易的方式。你可以在这些场景中将 Vue 想象成 jQuery 的一个更加声明式的替代。
Vue 也提供了另一个适用于此类无构建步骤场景的替代版 petite-vue,主要为渐进式增强已有的 HTML 作了特别的优化。功能更加精简,十分轻量。
嵌入 Web Component
你可以用 Vue 来构建标准的 Web Component,这些 Web Component 可以嵌入到任何 HTML 页面中,无论它们是如何被渲染的。这个选项允许你以一种完全与消费者无关的方式使用 Vue:因为生成的 Web Component 可以嵌入到旧版本的应用、静态 HTML,甚至用其他框架构建的应用中。
单页面应用 (SPA)
一些应用在前端需要具有丰富的交互性和并不简单的有状态逻辑。构建这类应用的最佳方法是使用这样一种架构:Vue 不仅控制整个页面,还可以处理数据更新和导航,而无需重新加载页面。这种类型的应用通常称为单页面应用 (Single-Page application,SPA)。
Vue 提供了核心功能库和综合性的工具链支持,为现代 SPA 提供了极佳的开发体验,包括以下内容:
- 客户端路由
- 极其快速的构建工具
- IDE 支持
- 浏览器开发工具
- TypeScript 集成
- 测试工具
SPA 一般都依赖后端来暴露 API 端点,但你也可以将 Vue 和如 Inertia.js 之类的解决方案搭配使用,在保留以服务器为中心的开发模型的同时获得 SPA 的益处。
全栈 / SSR
纯客户端的 SPA 在首屏加载和 SEO 方面有显著的问题。这是因为浏览器会收到一个巨大的 HTML 空页面,必须等到 JavaScript 加载完毕再渲染。
Vue 为服务端将一个 Vue 应用渲染成 HTML 字符串提供了第一优先级支持的 API。这使得服务器能够分发渲染好的 HTML,允许用户在 JavaScript 下载时看到页面内容。Vue 之后会在客户端对应用进行“激活 (hydrate)”使其重获可交互性。这被称为服务端渲染 (SSR),它极大地改善了 Web 应用在核心指标上的性能表现,如最大内容绘制 (LCP)。
也有一些针对此类场景、基于 Vue 构建的框架,比如 NuxtJS,允许你使用 Vue 和 JavaScript 开发一个全栈应用。
JAMStack / SSG
如果所需的数据是静态的,那么服务端渲染可以提前完成。这意味着我们可以将整个应用预渲染为 HTML,并将其作为静态文件提供。这增强了站点的性能表现,也使部署变得更容易,因为我们无需根据请求动态地渲染页面。Vue 仍可通过激活在客户端提供交互。这一技术通常被称为静态站点生成 (SSG),也被称为 JAMStack。
Vue 团队维护了一个静态站点生成器 VitePress,你正在阅读的文档也是基于它构建的!另外,NuxtJS 也支持 SSG。你甚至可以在同一个 Nuxt 应用中通过不同的路由提供 SSR 和 SSG。
Web 之外...
尽管 Vue 主要是为构建 Web 应用而设计的,但它绝不仅仅局限于浏览器。你还可以: