gpt4 book ai didi

angularjs - 从 angularjs 中的服务调用 Controller 函数

转载 作者:行者123 更新时间:2023-12-02 21:43:56 25 4
gpt4 key购买 nike

我正在使用 socket.io 在我的应用程序中启用聊天,并且我正在使用服务 SocketService 来执行所有套接字操作。当消息到来时,我想从服务 SocketService 触发 Controller 的功能,以在 UI 中进行一些更改。所以我想知道如何从服务访问 Controller 的功能。示例代码:

.service('SocketService', function ($http,$rootScope,$q) {
this.connect = function(){
var socket = io();
socket.on('connect',function(){
// Call a function named 'someFunction' in controller 'ChatController'
});
}
});

这是服务的示例代码。

现在是 Controller 的代码

.controller('ChatController',function('SocketService',$scope){
$scope.someFunction = function(){
// Some Code Here
}
});

最佳答案

您可以通过使用 Angular 事件 $broadcast$emit 来实现此目的。

在你的情况下$broadcast会很有帮助,您需要在 $rootscope 中广播您的事件,该事件可以被具有相同事件名称的 $on 的所有子作用域监听。

代码

.service('SocketService', function($http, $rootScope, $q) {
this.connect = function() {
var socket = io();
socket.on('connect', function() {
// Call a function named 'someFunction' in controller 'ChatController'
$rootScope.$broadcast('eventFired', {
data: 'something'
});
});
}
});


.controller('ChatController', function('SocketService', $scope) {
$scope.someFunction = function() {
// Some Code Here
}
$scope.$on('eventFired', function(event, data) {
$scope.someFunction();
})
});

希望对您有帮助,谢谢。

关于angularjs - 从 angularjs 中的服务调用 Controller 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28884028/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com