单文件组件

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

    • 全局定义 (Global definitions) 强制要求每个 component 中的命名不得重复
    • 字符串模板 (String templates) 缺乏语法高亮,在 HTML 有多行的时候,需要用到丑陋的
    • 不支持 CSS (No CSS support) 意味着当 HTML 和 JavaScript 组件化时,CSS 明显被遗漏

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

    这是一个文件名为 的简单实例:

    现在我们获得:

    这些特定的语言只是例子,你可以只是简单地使用 Babel,TypeScript,SCSS,PostCSS 或者其他任何能够帮助你提高生产力的预处理器。如果搭配 vue-loader 使用 webpack,它也能为 CSS Modules 提供头等支持。

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

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

    起步

    如果你希望深入了解并开始使用单文件组件,请来 CodeSandbox 看看这个简单的 todo 应用单文件组件 - 图3 (opens new window)

    • Node 包管理器 (npm): 阅读 中关于如何从注册地 (registry) 获取包的章节。

    在你花一天时间了解这些资源之后,我们建议你参考 Vue CLI单文件组件 - 图4 (opens new window)。只要遵循指示,你就能很快地运行一个带有 .vue 组件、ES2015、webpack 和热重载 (hot-reloading) 的 Vue 项目!

    CLI 会为你搞定大多数工具的配置问题,同时也支持细粒度自定义。

    有时你会想从零搭建你自己的构建工具,这时你需要通过 Vue Loader单文件组件 - 图5 (opens new window) 手动配置 webpack。关于学习更多 webpack 的内容,请查阅和 Webpack Academy单文件组件 - 图6 (opens new window)