I have an AngularJS service defined in the following way
angular.module('myService').service('myService', function() {
this.publicFunction(param) {
...
};
this.anotherPublicFunction(param) {
// how to call publicFunction(param)?
...
};
});
and I would like to call the first function both from outside the service (which works fine by myService.publicFunction(xxx)
) and from another function in the same service, i.e. anotherPublicFunction
. Neither one of this.publicFunction(param)
or myService.publicFunction(param)
won't work from within the second function, and I can understand that.
EDIT:
Actually the whole problem was caused by something you can't reproduce with my example alone. I passed the second function as a callback parameter to another function in a separate controller, and when it is called, the reference to this
doesn't work.
E.g.
anotherService.someCall('a', 123, myService.anotherPublicFunction);
fails inside anotherPublicFunction
because this
can't be resolved.
I've written a Plunker to show the problem: http://plnkr.co/edit/rrRs9xnZTNInDVdapiqF?p=info
(I'll still leave the question here in case it will help someone else.)
I know I could get around the problem by using a reference to the service or the first function like this
var ms = this;
this.anotherPublicFunction(param) {
ms.publicFunction(param);
...
};
or this
var pf = this.publicFunction;
this.anotherPublicFunction(param) {
pf(param);
...
};
but both seem like dirty hacks.
Is there a good way to call the first function from the second one in this case? Or am I doing something totally wrong in the first place to have a service like this?
I found these questions with good answers:
but they differ from my problem since one of them has a separate, internal function that was to be called, and the other one was using a factory instead of a service.
EDIT:
After posting this I immediately realized I could also do this:
var actualWork = function(param) {
...
}
this.publicFunction(param) {
actualWork(param);
};
this.anotherPublicFunction(param) {
actualWork(param);
...
};
which doesn't seem quite as bad as the other options so far... Are there better approaches?
var ms = this;
(which is written more often asvar self = this;
) "a dirty hack"? – Mikhail Batcerthis
in the same scope just feels weird... Butthis
is a special reference and JavaScript has this kind of lexical closure, so it's one of those things I should probably just accept and embrace when writing JS code. When in Rome etc. – MJV