Node.js backbone.js sending“;选项“;作为一个平静的请求

Node.js backbone.js sending“;选项“;作为一个平静的请求,node.js,backbone.js,express,Node.js,Backbone.js,Express,主干与本地运行os x 10.6.8的node/express对话。尝试用fetch填充客户端主干模型。以为我搞错了。大部分app_stuff.js都是剪切粘贴的。好奇为什么node/express将请求视为选项而不是GET(或POST?)以及我是否掌握了正确的术语。我想我可以让它像这样工作,但我宁愿支付一些最佳实践的费用,而仍然是一个绝对的新手 骨干 (function($) { var Stuff = Backbone.Model.extend({ }); var

主干与本地运行os x 10.6.8的node/express对话。尝试用fetch填充客户端主干模型。以为我搞错了。大部分app_stuff.js都是剪切粘贴的。好奇为什么node/express将请求视为选项而不是GET(或POST?)以及我是否掌握了正确的术语。我想我可以让它像这样工作,但我宁愿支付一些最佳实践的费用,而仍然是一个绝对的新手

骨干

(function($) {
    var Stuff = Backbone.Model.extend({

    });
    var Collec = Backbone.Collection.extend({
        model: Stuff,
        url: 'http://localhost:3000/stuff'
    });
    var nstuff = new Collec;
    nstuff.fetch(
        { data: $.param({ name: "helloworld"}) }
    );
})(jQuery);
app_stuff.js

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

var app = express();

app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.get('/', routes.index);
app.get('/users', user.list);
app.get('/stuff', stuff.index);
app.options('/stuff', function() { console.log("stuffed"); });

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

$ node timeline/app_stuff.js 
Express server listening on port 3000
stuffed

通常情况下,在GET请求之前会发送一个选项请求作为飞行前请求,以验证请求者是否可以访问域…请参见此处的第二个答案…whew滥用了该单词request,但我希望您收到我的回复。应用程序在localhost:3000上运行?如果不是,则为跨域请求,并发送选项以检查是否允许源标题