Development Tip

Node.js에서 경로 구성

yourdevel 2020. 12. 3. 20:45
반응형

Node.js에서 경로 구성


Node.js를보기 시작합니다. 또한 Express를 사용하고 있습니다. 질문이 있습니다. 웹 애플리케이션 경로를 어떻게 구성 할 수 있습니까? 모든 예제는이 모든 app.get/post/put()핸들러를 app.js에 넣고 잘 작동합니다. 이것은 좋지만 단순한 HW 블로그 이상의 것이 있다면? 다음과 같이 할 수 있습니까?

var app = express.createServer();
app.get( '/module-a/*', require('./module-a').urls );
app.get( '/module-b/*', require('./module-b').urls );

// file: module-a.js
urls.get('/:id', function(req, res){...}); // <- assuming this is handler for /module-a/1

즉, Django의 URLConf와 같은 것이지만 Node.js를 원합니다.


여기에서 예제를 확인하십시오.

https://github.com/visionmedia/express/tree/master/examples

'mvc'및 'route-separation'이 도움이 될 수 있습니다.


´ Smashing Node.js : JavaScript Everywhere ´에서 내가 정말 좋아 하는 간단한 예제를 찾았습니다 .

고유 한 익스프레스 애플리케이션 을 정의 module-a하고 module-bconnects app.use ()를 사용하여 원하는대로 기본 애플리케이션에 마운트 할 수 있습니다 .

module-a.js

module.exports = function(){
  var express = require('express');
  var app = express();

  app.get('/:id', function(req, res){...});

  return app;
}();

module-b.js

module.exports = function(){
  var express = require('express');
  var app = express();

  app.get('/:id', function(req, res){...});

  return app;
}();

app.js

var express = require('express'),
    app = express();

app.configure(..);

app.get('/', ....)
app.use('/module-a', require('./module-a'));    
app.use('/where/ever', require('./module-b'));    

app.listen(3000);

이것은 당신에게 경로를 줄 것입니다

localhost:3000/
localhost:3000/module-a/:id
localhost:3000/where/ever/:id

@tjholowaychuk (express의 제작자)의 스크린 캐스트도 있으며 여기서 @Vegar가 설명한 방법을 사용합니다.

Vimeo에서 사용 가능 : Node.js 및 Express를 사용하는 모듈 식 웹 애플리케이션


또 하나의 대안;

App.js

var express = require('express')
      , routes = require('./routes')
      , user = require('./routes/user')
      , http = require('http')
      , path = require('path');

    var app = express();


// all environments
app.set('port', process.env.PORT || 3000);


app.get('/', routes.index);
app.get('/users/:id', user.getUser);

http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

index.js

exports.index = function(req, res){
  res.render('index', { title: 'Express' });
};

user.js

exports.getUser = function(req, res){


    //your code to get user

};

체크 아웃 기사 에 대한 명시-routescan 노드 모듈을 . 이 모듈은 Express 애플리케이션을위한 유지 관리 가능한 라우팅을 구성하는 데 도움이됩니다. 시도해 볼 수 있습니다. 이것이 저에게 가장 적합한 솔루션입니다.


몇 가지 방법이 있습니다.

1:

module1(app.route('/route1'));
module2(app.route('/route2'));

In the modules you can just implement 1 function to handle the http methods:

module.exports = function(route) {
   route
   .get(function(req, res, next) {
       ...
   }).
   .post(function(req, res, next) {
      ...
   });
}

2: if you want to handle the route by a sub-app instead of a module/middleware :

var m1 = require(module1.js);
var m2 = require(module2.js);

app.use('/route1', r1);
app.use('/route2', r2);

참고URL : https://stackoverflow.com/questions/4602212/organize-routes-in-node-js

반응형