嘿,我遇到了一个奇怪的问题。我的socket.emit
正在为我的一个控制器工作,但它不适用于另一个控制器。socket.emit只适用于一个控制器AngularJS
server.js(服务器端)
io.sockets.on('connection', function(socket){
console.log('User ' + socket.id + ' connected');
socket.emit('test');
});
QueueController.js(客户端)(工作)
app.controller('QueueController', ['$scope', '$location', '$rootScope', 'socket',
function($scope, $location, $rootScope, socket){
socket.on('chat start', function(data){
$rootScope.$apply(function(){
$location.path('/chat');
});
});
socket.on('test', function(){
console.log('hello world'); //this displays fine in the console
});
});
ChatController(客户端) (不工作)
app.controller('ChatController', ['$scope', '$rootScope', 'socket',
function($scope, $rootScope, socket){
socket.on('test', function(){
console.log('hello world'); //this does not display at all
});
});
我读过一个需要包装内
socket.on('connect', function(){ ... }
的socket.emit
,但没有奏效。
这是我的路线:
app.js
var app = angular.module('ChatApp', ['ngRoute', 'ngAnimate', 'luegg.directives', 'btford.socket-io']);
app.config(function($routeProvider, $locationProvider){
$routeProvider
.when('/', {
controller:'HomeController',
templateUrl:'views/home.html'
})
.when('/queue', {
controller:'QueueController',
templateUrl:'views/queue.html'
})
.when('/chat', {
controller:'ChatController',
templateUrl:'views/chat.html'
})
.otherwise({
redirectTo: '/'
});
});
任何想法有什么不对?
您知道根据您当前的路线只有一个控制器处于活动状态吗? – Quad
我不知道。我必须做什么才能切换到新的主动控制器?可能吗? – Student22
当您访问http:// yourapp/queue时,将获得您在路由配置中定义的模板和控制器。如果你去/聊天(你可以输入网址栏或在页面的某个地方放一个链接),你可以通过它的模板获得chatcontroller。如果你想要一个路由器中的附加控制器,你需要将一个带有ng-controller的元素放在你的模板中。 – Quad