首次尝试使用node.js,与其他人一样创建一个简单的实时聊天应用程序。
一直遇到问题,并且持续约2个小时找不到解决方案/原因。
我最初在聊天应用程序中遇到了这个问题,对服务器的每个单个请求都会重复,因此消息将出现两次,在控制台中,加入服务器将记录两次。我已经实施了一些解决方案,因为这里有很多类似的问题,但是都没有解决。
我试图在新的测试应用程序中重新创建该问题,以查看是否可以找到我做错的事情。
服务器代码
var express = require('express');
var routes = require('./routes');
var path = require('path');
var http = require('http');
var app = module.exports = express();
var server = require('http').createServer(app);
var io = require('socket.io').listen(server);
app.set('port', 1620);
app.use(express.logger('dev'));
app.use(express.methodOverride());
app.use(express.static(path.join(__dirname, 'public')));
app.use(app.router);
app.set('views', __dirname + '/views');
app.engine('html', require('ejs').renderFile);
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/', routes.index);
io.sockets.on('connection', function (socket) {
socket.on('test', function (data) {
console.log('Test.' + data);
});
});
server.listen(app.get('port'), app.get('ipaddr'), function () {
console.log('Express server listening on IP/hostname: "' + app.get('ipaddr') + '" and port: "' + app.get('port') + '"');
});
客户代码:
'use strict';
angular.module('chatter', []);
angular.module('chatter').controller('chatterCtrl', [
'$scope', '$http', function ($scope, $http) {
$scope.test = 'Hello';
var socket = io.connect();
$scope.sendTest = function () {
socket.emit('test', 'ThisIsATest');
}
}
]);
$ scope.sendTest绑定到单击按钮的位置。
这是控制台日志...
(不会让我发布图片)
Test.1
Test.1
Test.2
Test.2
Test.3
Test.3
Test.4
Test.4
Test.5
Test.5
Test.6
Test.6
与其他类似问题不同,这个问题不是应有的。
要调用Favicon(具有express.favicon,它会在所有浏览器中的每个调用中发生)
对于被多次调用的事件处理程序,该请求始终仅重复一次,与连接4个客户端或刷新该请求仅两次调用无关紧要。
谁能从我的代码中看到问题所在?如果您运行此代码,是否会得到相同的输出?
干杯。
最佳答案
从注释中可以看出,该问题与我最初想到的与node.js / socket.io无关,问题是我两次声明了我的角度脚本,导致我的角度控制器被所有事物调用了两次。
<script src="~/Scripts/angular.js" type="text/javascript"></script>
<script src="~/Scripts/angular.js" type="text/javascript"></script>
删除重复的声明可解决此问题。