2
Windows에서 node.js를 사용하는 로컬 앱을 만들고 있습니다. 아이디어는 특정 파일을보고 파일이 변경되면 브라우저에 내용을 전송하는 것입니다.Node.js fs.watch - 단일 변경으로 여러 번 출력합니다.
지금 테스트를 위해 콘솔에서 파일의 fs.watch를보고 있습니다. 내가 주목 한 것은 내가보고있는 파일을 한 번 변경하면 콘솔에 이중 출력이 생성된다는 것입니다. fs.watch 콘솔에 이중 출력을 생성하는 이유에
<!doctype html>
<html>
<head>
<title>Socket.IO demo</title>
</head>
<body>
<h1>Socket.IO demo</h1>
<input type="text" autofocus="autofocus" />
<button type="button">publish</button>
<button type="button">broadcast</button>
<button type="button">whisper</button>
<p>Status: <span id="status">Undefined</span></p>
<ol id="messages"></ol>
<script src="/socket.io/socket.io.js"></script>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script src="http://jashkenas.github.com/coffee-script/extras/coffee-script.js"></script>
<script type="text/coffeescript">
jQuery ($) ->
$status = $ '#status'
socket = io.connect()
socket.on 'connect', ->
$status.text 'Connected'
socket.on 'disconnect', ->
$status.text 'Disconnected'
socket.on 'reconnecting', (seconds) ->
$status.text "Reconnecting in #{seconds} seconds"
socket.on 'reconnect', ->
$status.text 'Reconnected'
socket.on 'reconnect_failed', ->
$status.text 'Failed to reconnect'
socket.on 'message', (message) ->
$('<li>').text(message).appendTo $('#messages')
socket.on 'secret', (message) ->
console.log message
$input = $ 'input'
$('button').click ->
socket.emit $(this).text(), $input.val()
$input.val('').focus()
</script>
</body>
</html>
어떤 생각 :
여기var fs, http, io, server;
fs = require('fs');
http = require('http');
server = http.createServer(function(req, res) {
return fs.readFile("" + __dirname + "/socket.io.demo.html", function(err, data) {
res.writeHead(200, {
'Content-Type': 'text/html'
});
return res.end(data, 'utf8');
});
});
server.listen(1337);
fs.watch('/', function (event, filename) {
console.log('event is: ' + event);
if ('test.txt') {
console.log('filename provided: ' + filename);
} else {
console.log('filename not provided');
}
});
io = require('socket.io').listen(server);
io.sockets.on('connection', function(socket) {
socket.on('publish', function(message) {
return io.sockets.send(message);
});
socket.on('broadcast', function(message) {
return socket.broadcast.send(message);
});
return socket.on('whisper', function(message) {
return socket.broadcast.emit('secret', message);
});
});
는 HTML입니다 : 여기
서버입니까?
감사합니다. Logan. 나는 그 버그를 보지 못했습니다. – imallhere