Files
freeCodeCamp/curriculum/challenges/chinese-traditional/06-quality-assurance/advanced-node-and-express/clean-up-your-project-with-modules.md
Nicholas Carrigan (he/him) 3da4be21bb chore: seed chinese traditional (#42005)
Seeds the chinese traditional files manually so we can deploy to
staging.
2021-05-05 22:43:49 +05:30

2.3 KiB
Raw Permalink Blame History

id, title, challengeType, forumTopicId, dashedName
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.
*/