快递中的奇怪行为用于听取请求

时间:2013-08-05 03:09:56

标签: node.js express

我的应用程序只是简单地接受输入并将其存储在一个数组中然后将其删除但是这是我按顺序输入1234567890时得到的结果

 Express server listening on port 3000
 1 1
 0
 12 1
 0
 123 1
 0
 1234 1
 0
 12345 1
 0
 123456 1
 0

然后在显示此

之前停止约3分钟
 1234567 1
 0
 12345678 1
 0 
 123456789 1
 0
 1234567890 1
 0

为什么会停止?好像有某种超时正在发生,或者有某种倾听者我没有正确处理

 var express      = require('express')
 , http         = require('http')
 , path         = require('path')
 , fs           = require('fs');

 var app = express();

 app.configure(function(){
      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')));
 });

 var queries = new Array();

 function printAndShiftArray() {
      console.log(queries + " " + queries.length);
  if (queries.length == 0) {
       console.log("array is empty");
  } else {
       queries.shift();
  }
       console.log(queries + " " + queries.length);
 }

 app.get('/', function (req, res) {
     res.sendfile(__dirname + '/index.html');
 });

 app.post('/search', function(req, res) {
 input = req.param('letter');
 queries.push(input);
 printAndShiftArray();
 }); 

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

使用此

调用/ search api
        $(document).ready(function() {
            $('#letter').on("keyup", function() {
                letter = $('#letter').val();
                $.post("/search", { letter: letter}, function(data) {
                    $('#status').html(data);
                });
            });
        });

1 个答案:

答案 0 :(得分:2)

您需要res.end('')处理程序中的/search

处理/search时,您没有结束回复。因此,当您点击“6”时,您的浏览器会打开6个并发请求,jQuery将不再发送。然后等待3分钟,直到这些请求超时(有错误,你没看到),然后它将发送剩余的4个。