0

私はnode.jsを学んでいます。以下のコードは、動作するはずの本から取られています。http.js:704 throw new Error('Can\'t set headers after they are sent.')localhost:8080/stooges/chat にアクセスするとスローされます

var express = require('express');
var http = require('http');
var app = express();
var server = http.createServer(app);
var io = require('socket.io').listen(server);
var catchPhrases = ['Why I oughta...', 'Nyuk Nyuk Nyuk!', 'Poifect!', 'Spread out!',   
'Say a few syllables!', 'Soitenly!'];

app.set('view engine', 'jade');
app.set('view options', { layout: true });
app.set('views', __dirname + '/views');

app.get('/stooges/chat', function(req, res, next) {
res.render('chat');
});

io.sockets.on('connection', function(socket) {
var sendChat = function( title, text ) {
    socket.emit('chat', {
        title: title,
        contents: text
    });
};

setInterval(function() {
    var randomIndex = Math.floor(Math.random()*catchPhrases.length)
    sendChat('Stooge', catchPhrases[randomIndex]);
}, 5000);

sendChat('Welcome to Stooge Chat', 'The Stooges are on the line');
socket.on('chat', function(data){
    sendChat('You', data.text);
});
});

app.get('/?', function(req, res){
res.render('index');
});

var port = 8080;
server.listen(port);
console.log('Listening on port ' + port);

上記のコードのどの行でエラーが発生しますか? なぜ?

更新: 行をコメントアウトしましたがvar io = require('socket.io').listen(server);、それがエラーの原因となっているようです。

更新: robertklep のリクエストに応じて、チャット テンプレートは次のとおりです。

extends layout

block scripts
script(type='text/javascript', src='/socket.io/socket.io.js')
script(type='text/javascript')
    var socket = io.connect('http://192.168.1.34:8080');
    socket.on('chat', function(data) {
        document.getElementById('chat').innerHTML =
        '<p><b>' + data.title + '</b>: ' + data.contents + '</p>';
    });
    var submitChat = function(form) {
        socket.emit('chat', {text: form.chat.value});
        return false;
    };

block content
div#chat

form(onsubmit='return submitChat(this);')
    input#chat(name='chat', type='text')
    input(type='submit', value='Send Chat')
4

1 に答える 1

1

そのため、間違ったバージョンの socket.io を使用していたことがわかりました。pakcage.json の依存関係を 0.9.10 から 0.9.14 に更新したところ、機能しました。助けてくれてありがとう!

于 2013-04-27T08:46:39.203 に答える