0

我想在侦听器中使用依赖项,但 websocket 是undefined

$rootScope.$on('websocket.connected', function() {
    $websocket.request(.....).then();
});

并且想要在准备好时调用服务方法(依赖于异步方法)

app.controller('MyCtrl', function(myServ, $log) {
    myServ.getInfos();
});

谢谢你。

jsfiddle http://jsfiddle.net/8DHfY/3/或此处的代码

var app = angular.module('myApp', ['myServ'])
.config(['$websocketProvider', function ($websocketProvider) {
    $websocketProvider.setHost('ws://echo.websocket.org/');
}])
.controller('MyCtrl', function(myServ, $log) {
    $log.log('I want to call myServ.getInfos() from a controler');
});

angular.module('myServ', ['websocket']).service('myServ', ['$log', '$rootScope', '$websocket', function($log, $rootScope, $websocket) {

    $log.error('websocket is %o ... ???', $websocket); // return undefined

    $rootScope.$on('websocket.connected', function() {
        $log.error('websocket is still %o', $websocket); // return undefined
    });

    return {
        getInfos: function() {
            $websocket.request(JSON.stringify({'key': 'value'}));
        }
    };
}]);

angular.module('websocket', []).provider('$websocket', [function() {

    var _this = this;

    _this.host = '';
    _this.connection = null;

    _this.setHost = function(host) {
        this.host = host;
        return this;
    };

    _this.request = function(request) {
        //request method for websocket
    };

    this.$get = ['$log', '$rootScope', function($log, $rootScope) {

        _this.connection = new WebSocket(this.host);
        _this.connection.onopen = function(){
            $log.log('Websocket connected to %s', _this.host);
            $rootScope.$emit('websocket.connected');
        };
    }];
}]);
4

1 回答 1

0

提供者在注入时调用 $get 函数,并使用从该函数返回的任何内容的单例。

这意味着由于您没有从 $get 函数返回任何内容,因此它使用未定义。

这是一个更新的小提琴:http: //jsfiddle.net/8DHfY/4/

this.$get = ['$log', '$rootScope', function($log, $rootScope) {

    _this.connection = new WebSocket(this.host);
    _this.connection.onopen = function(){
        $log.log('Websocket connected to %s', _this.host);
        $rootScope.$emit('websocket.connected');
    };
    return _this;
}];
于 2014-01-24T01:11:31.693 回答