7

express.jsから来て、 flatironに小さなプロジェクトを試してみたいと思います。しかし、私が実際にどこかに行くのを妨げるいくつかの小さな問題があります。

var flatiron = require('flatiron')
,  session = require('connect').session
,  ecstatic = require('ecstatic')
,  path = require('path')
,  fs = require('fs')
,  plates = require('plates')
,  director = require('director')
,  winston = require('winston')
,  union = require('union');

var router = new director.http.Router();
var server = union.createServer({
  before: [
    ecstatic(__dirname + '/public')
  ]
});

router.get('/', function () {
  var self = this;
  fs.readFile('public/layout.html', 'utf-8', function(err, html) {
    [...]
  })
});

server.listen(3000, function () {
  console.log('Application is now started on port 3000');
});

ディレクターによるルーティングはどのように機能しますか?恍惚としたままにしておくと、「/」のようなルートを定義でき、それは機能しますが、静的なCSSおよびJSコンテンツを取得できません。ecstatic /は「index.html」に置き換えられ、ecstaticは定義されたすべてのルートよりも優先されます。-これはconnect-staticの場合と同じ動作です。ルート(/)はindex.htmlに置き換えられます。

また、接続ミドルウェアを使用して別のアプローチを試しましたが、機能しません。

var flatiron = require('flatiron')
,  connect = require('connect')
,  path = require('path')
,  fs = require('fs')
,  plates = require('plates')
,  app = flatiron.app;

app.use(flatiron.plugins.http);
app.use(connect.favicon());
app.use(connect.static(__dirname + '/public'));
app.use(connect.directory(__dirname + '/public'));
app.use(connect.cookieParser('my secret here'));
app.use(connect.session({'secret': 'keyboard cat'}));

app.router.get('/', function () {
  console.log("GET /");
  var self = this;
  fs.readFile('public/layout.html', 'utf-8', function(err, html) {
    [...]
  })
});

app.listen(3000, function () {
  console.log('Application is now started on port 3000');
});
4

2 に答える 2

4

フラットアイアンでのルーティングに関するあなたの質問に対する最良の答えは、いつものように、ソースコード内にあると思います。

     app.server = union.createServer({
           after: app.http.after,
           before: app.http.before.concat(function (req, res) {
             if (!app.router.dispatch(req, res, app.http.onError || union.errorHandler)) {
               if (!app.http.onError) res.emit('next');
             }
           }),
           headers: app.http.headers,
           limit: app.http.limit
     });

ここでわかるように、flatironは、すべてのミドルウェアの後に呼び出される最後の要求ハンドラーとしてルーターをバインドします。app.http.beforeに「ecstatic」を配置し、ワークフロー中にディスパッチされる場合、他のミドルウェアは呼び出されません。

コードの2番目のブロックは、Flatironの.use()メソッドとExpress/Connectのメソッドの違いを理解できないことを示しています。この例で明確にしようと思います:

    flatironApp.use({
        // plugin object
        name : "pluginName"
      , attach : function(options) {  
          /*code*/  
      }
      , init : function(done) { 
          /*code*/ 
          done(); 
      }
    })

    connectApp.use(function(req, res, next) {
      /* code */
      next();
    })

FlatironでConnectのミドルウェアを使用する場合は、次のようにそれぞれapp.http.before配列に配置する必要があります。

    // Initiating application
    app.use(flatiron.plugins.http);

    // Adding request handlers
    app.http.before.push( connect.favicon() );
    app.http.before.push( ecstatic(__dirname + '/public') );
于 2012-03-26T19:09:07.670 に答える
2
var connect = require('connect');

var server = union.createServer({
  before: [
    function (req, res) {
      var found = router.dispatch(req, res);
        if (!found) {
          res.emit('next');
      }
    },
    connect.static('public')
  ]
});

ディスパッチ機能を挿入するのを忘れました。これは機能します。

于 2012-03-19T15:02:07.093 に答える