Skip to content
This repository was archived by the owner on Aug 8, 2022. It is now read-only.

proofread: src/guide/single-file-component.md #232

Merged
merged 3 commits into from
Oct 26, 2020
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 7 additions & 7 deletions src/guide/single-file-component.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@

在很多 Vue 项目中,我们使用 `app.component` 来定义全局组件,紧接着用 `app.mount('#app')` 在每个页面内指定一个容器元素。

这种方式在很多中小规模的项目中运作的很好,在这些项目里 JavaScript 只被用来加强特定的视图。但当在更复杂的项目中,或者你的前端完全由 JavaScript 驱动的时候,下面这些缺点将变得非常明显:
这对于中小型项目非常有效,在这些项目里 JavaScript 只被用来增强特定的视图。但当在更复杂的项目中,或者你的前端完全由 JavaScript 驱动的时候,下面这些缺点将变得非常明显:

- **全局定义 (Global definitions)** 强制要求每个 component 中的命名不得重复
- **字符串模板 (String templates)** 缺乏语法高亮,在 HTML 有多行的时候,需要用到丑陋的 `\`
- **不支持 CSS (No CSS support)** 意味着当 HTML 和 JavaScript 组件化时,CSS 明显被遗漏
- **没有构建步骤 (No build step)** 限制只能使用 HTML 和 ES5 JavaScript,而不能使用预处理器,如 Pug (formerly Jade) 和 Babel
- **全局定义 (Global definitions)** 强制要求每个 component 中的命名不得重复;
- **字符串模板 (String templates)** 缺乏语法高亮,在 HTML 有多行的时候,需要用到丑陋的 `\`;
- **不支持 CSS (No CSS support)** 意味着当 HTML 和 JavaScript 组件化时,CSS 明显被遗漏;
- **没有构建步骤 (No build step)** 限制只能使用 HTML 和 ES5 JavaScript,而不能使用预处理器,如 Pug (曾经的 Jade) 和 Babel

所有这些都可以通过扩展名为 `.vue` 的 **single-file components (单文件组件)** 来解决,并且还可以使用 webpack 或 Browserify 等构建工具。

Expand All @@ -31,7 +31,7 @@

### 怎么看待关注点分离?

一个重要的事情值得注意,**关注点分离不等于文件类型分离**。在现代 UI 开发中,我们已经发现相比于把代码库分离成三个大的层次并将其相互交织起来,把它们划分为松散耦合的组件再将其组合起来更合理一些。在一个组件里,其模板、逻辑和样式是内部耦合的,并且把他们搭配在一起实际上使得组件更加内聚且更可维护。
值得注意的是,**关注点分离不等于文件类型分离**。在现代 UI 开发中,我们已经发现相比于把代码库分离成三个大的层次并将其相互交织起来,把它们划分为松散耦合的组件再将其组合起来更合理一些。在一个组件里,其模板、逻辑和样式是内部耦合的,并且把他们搭配在一起实际上使得组件更加内聚且更可维护。

即便你不喜欢单文件组件,你仍然可以把 JavaScript、CSS 分离成独立的文件然后做到热重载和预编译。

Expand All @@ -46,7 +46,7 @@

## 起步

### 例子沙箱
### 在线演示

如果你希望深入了解并开始使用单文件组件,请来 CodeSandbox [看看这个简单的 todo 应用](https://codesandbox.io/s/vue-todo-list-app-with-single-file-component-vzkl3?file=/src/App.vue)。

Expand Down