.config, .run, AppCtrl - where to put routes?

Martin picture Martin · Aug 8, 2013 · Viewed 31.8k times · Source

I wanted to find out the difference between the .config and .run functions in AngularJS. I was using my .config for setting up routes, but I did have some $on's for watching route change start and success events.

I then moved some of this code to .run as I was having some dependency injection problems in .config.

I finally moved some of this to a CommonAppController which I have set on my <body>.

I also had 2 .config's and it seemed to be running ok, but surely this isn't right?

Can anyone give a little insight on which method to use?

Answer

Steve Kl&#246;sters picture Steve Klösters · Aug 8, 2013

Configuration blocks and run blocks get executed at different points in the application bootstrap, and have different injection locals at their disposal. Here's a summary of what you can find in the AngularJS documentation.

Configuration blocks (registered with module.config()) get executed during provider registration, and can only be injected providers and constants (see module.provider() and module.constant()). This is typically where you would configure application-wide stuff, such as the $routeProvider. Stuff that needs to be configured before the services are created.

Run blocks (registered with module.run()) get executed after the injector has all the providers. Now, all instances and constants can be injected. This is typically where you would configure services, $rootScope, events and so on.

You can have multiple of either, and they are executed in the order they were registered to the module. Some people prefer to register a configuration block before every group of controllers to register the routes to these controller, for example.