Node.js
Struktura Route-Controller-Service dla ExpressJS
Szukaj…
Model-Routes-Controllers-Services Struktura katalogu
├───models
│ ├───user.model.js
├───routes
│ ├───user.route.js
├───services
│ ├───user.service.js
├───controllers
│ ├───user.controller.js
W przypadku modułowej struktury kodu logikę należy podzielić na te katalogi i pliki.
Modele - definicja schematu modelu
Trasy - interfejs API trasuje mapy do kontrolerów
Kontrolery - kontrolery obsługują całą logikę związaną z weryfikacją parametrów żądania, zapytania, wysyłania odpowiedzi z poprawnymi kodami.
Usługi - usługi zawierają zapytania do bazy danych i zwracają obiekty lub zgłaszają błędy
Ten koder ostatecznie skończy pisać więcej kodów. Ale na koniec kody będą znacznie łatwiejsze w utrzymaniu i oddzielone.
Model-Trasy-Kontrolery-Struktura kodu usług
user.model.js
var mongoose = require('mongoose')
const UserSchema = new mongoose.Schema({
name: String
})
const User = mongoose.model('User', UserSchema)
module.exports = User;
user.routes.js
var express = require('express');
var router = express.Router();
var UserController = require('../controllers/user.controller')
router.get('/', UserController.getUsers)
module.exports = router;
user.controllers.js
var UserService = require('../services/user.service')
exports.getUsers = async function (req, res, next) {
// Validate request parameters, queries using express-validator
var page = req.params.page ? req.params.page : 1;
var limit = req.params.limit ? req.params.limit : 10;
try {
var users = await UserService.getUsers({}, page, limit)
return res.status(200).json({ status: 200, data: users, message: "Succesfully Users Retrieved" });
} catch (e) {
return res.status(400).json({ status: 400, message: e.message });
}
}
user.services.js
var User = require('../models/user.model')
exports.getUsers = async function (query, page, limit) {
try {
var users = await User.find(query)
return users;
} catch (e) {
// Log Errors
throw Error('Error while Paginating Users')
}
}
Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow