freeCodeCamp/curriculum/challenges/chinese/06-quality-assurance/advanced-node-and-express/clean-up-your-project-with-...

2.3 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
589690e6f9fc0f352b528e6e 使用模块清理项目 2 301549 clean-up-your-project-with-modules

--description--

目前,我们把所有的代码都放到了 server.js 文件里, 这会导致代码难以维护,且扩展性差。 现在让我们来创建两个新文件:routes.jsauth.js

在每个文件的开头,我们都需要写上这段代码:

module.exports = function (app, myDataBase) {

}

然后,在 server.js 文件的开头,像这样引入文件:const routes = require('./routes.js');。在成功连接数据库之后,像这样进行实例化:routes(app, myDataBase)

最后,把所有路由相关的代码从 server.js 移动到新文件。 不要忘了,ensureAuthenticated 方法的定义也要移动到新文件中,这个是我们在之前的挑战中,为在路由中判断用户是否已登录创建的函数。 然后,在 routes.js文件开头添加所需要的依赖,如:const passport = require('passport');

如果在这些步骤后没有报错,那么你已成功地从 server.js 文件中分离出了路由文件(除了 catch block 中的路由

现在,我们来把 server.js 中与验证相关的代码分离到 auth.js 中,例如序列化,设置验证策略等。 请正确添加依赖,并在 server.js 中调用 auth(app, myDataBase)

完成上述要求后,请提交你的页面链接。 如果你遇到了问题,可以参考这里的答案。

--hints--

应该有模块。

(getUserInput) =>
  $.get(getUserInput('url') + '/_api/server.js').then(
    (data) => {
      assert.match(
        data,
        /require\s*\(('|")\.\/routes(\.js)?\1\)/gi,
        'You should have required your new files'
      );
      assert.match(
        data,
        /client\s*\.db[^]*routes/gi,
        'Your new modules should be called after your connection to the database'
      );
    },
    (xhr) => {
      throw new Error(xhr.statusText);
    }
  );

--solutions--

/**
  Backend challenges don't need solutions, 
  because they would need to be tested against a full working project. 
  Please check our contributing guidelines to learn more.
*/