As I understand it, when inside a factory I return an object that gets injected into a controller. When inside a service I am dealing with the object using this
For me the revelation came when I realise that they all work the same way: by running something once, storing the value they get, and then cough up that same stored value when referenced through Dependency Injection.
Say we have:
app.factory('a', fn);
app.service('b', fn);
app.provider('c', fn);
The difference between the three is that:
a's stored value comes from running fn , in other words: fn()b’s stored value comes from newing fn, in other words: new fn()c’s stored value comes from first getting an instance by newing fn, and then running a $get method of the instancewhich means, there’s something like a cache object inside angular, whose value of each injection is only assigned once, when they've been injected the first time, and where:
cache.a = fn()
cache.b = new fn()
cache.c = (new fn()).$get()
This is why we use this in services, and define a this.$get in providers.
Hope this helps.