本文转载自:众成翻译
译者:网络埋伏纪事
连接:http://www.zcfy.cc/article/1756
原文:https://blog.risingstack.com/node-hero-node-js-project-structure-tutorial/node
大多数 Node.js 框架不会提供固定的目录结构,而且从开始就作对可能就是一个挑战。本教程会学习如何正确组织一个 Node.js 项目的结构,从而在应用程序开始增加时避免混乱。npm
组织 Node.js 项目有很多可能的方式 - 而且每种已知的方式都有其兴衰。不过,根据咱们的经验,开发者总想实现一样的事情:干净的代码,以及轻松添加新功能的可能性。json
过去在 RisingStack,咱们有机会建立各类规模的高效 Node 应用程序,也得到了大量关于项目结构注意事项的看法。网络
咱们总结出了咱们在 Node.js 开发期间贯彻的五种简单指导原则。若是你设法遵循它们的话,你的项目将会更好:框架
假设有以下的目录结构:学习
// DON'T . ├── controllers | ├── product.js | └── user.js ├── models | ├── product.js | └── user.js ├── views | ├── product.hbs | └── user.hbs
这种方式的问题是:测试
要理解产品页是如何工做的,就必须打开三个不一样目录,须要有大量上下文切换,ui
在 require 模块时,要写长路径:require('../../controllers/user.js')
spa
要取代这种方式,你能够围绕产品功能/页面/组件来组织 Node.js 应用程序结构。这样作更容易理解一些:翻译
// DO . ├── product | ├── index.js | ├── product.js | └── product.hbs ├── user | ├── index.js | ├── user.js | └── user.hbs
index.js
文件中只使用这些 index.js 文件输出功能,好比:
// product/index.js var product = require('./product') module.exports = { create: product.create }
测试不单单是为了检查模块是否产生预期的输出,还用来文档化你的模块(在后续章节中会学到更多有关测试的内容)。所以,若是测试文件挨着实现文件放,会更容易理解。
将附加的测试文件放在一个单独的 test
文件夹中,避免冲突。
. ├── test | └── setup.spec.js ├── product | ├── index.js | ├── product.js | ├── product.spec.js | └── product.hbs ├── user | ├── index.js | ├── user.js | ├── user.spec.js | └── user.hbs
config
目录使用一个 config
目录放配置文件。
. ├── config | ├── index.js | └── server.js ├── product | ├── index.js | ├── product.js | ├── product.spec.js | └── product.hbs
scripts
目录为 package.json 中的附加长脚本建立一个单独的目录。
. ├── scripts | ├── syncDb.sh | └── provision.sh ├── product | ├── index.js | ├── product.js | ├── product.spec.js | └── product.hbs
下章将学习如何使用 Passport.js 验证用户身份。