Improve this DocBootstrap
This page explains the AngularJS initialization process and how you can manually initialize AngularJS if necessary.
AngularJS Tag
This example shows the recommended path for integrating AngularJS with what we call automatic initialization.
<!doctype html> <html xmlns:ng="http://angularjs.org" ng-app> <body> ... <script src="angular.js"></script> </body> </html>
- Place the
script
tag at the bottom of the page. Placing script tags at the end of the page improves app load time because the HTML loading is not blocked by loading of theangular.js
script. You can get the latest bits from http://code.angularjs.org. Please don't link your production code to this URL, as it will expose a security hole on your site. For experimental development linking to our site is fine.- Choose:
angular-[version].js
for a human-readable file, suitable for development and debugging. - Choose:
angular-[version].min.js
for a compressed and obfuscated file, suitable for use in production.
- Choose:
-
Place
ng-app
to the root of your application, typically on the<html>
tag if you want AngularJS to auto-bootstrap your application. -
If you choose to use the old style directive syntax
ng:
then include xml-namespace inhtml
when running the page in the XHTML mode. (This is here for historical reasons, and we no longer recommend use ofng:
.)
Automatic Initialization
AngularJS initializes automatically upon DOMContentLoaded
event or when the angular.js
script is evaluated if at that time document.readyState
is set to 'complete'
. At this point AngularJS looks for the ngApp
directive which designates your application root. If the ngApp
directive is found then AngularJS will:
- load the module associated with the directive.
- create the application injector
- compile the DOM treating the
ngApp
directive as the root of the compilation. This allows you to tell it to treat only a portion of the DOM as an AngularJS application.
<!doctype html> <html ng-app="optionalModuleName"> <body> I can add: {{ 1+2 }}. <script src="angular.js"></script> </body> </html>
As a best practice, consider adding an ng-strict-di
directive on the same element as ng-app
:
<!doctype html> <html ng-app="optionalModuleName" ng-strict-di> <body> I can add: {{ 1+2 }}. <script src="angular.js"></script> </body> </html>
This will ensure that all services in your application are properly annotated. See the dependency injection strict mode docs for more.
Manual Initialization
If you need to have more control over the initialization process, you can use a manual bootstrapping method instead. Examples of when you'd need to do this include using script loaders or the need to perform an operation before AngularJS compiles a page.
Here is an example of manually initializing AngularJS:
<!doctype html> <html> <body> <div ng-controller="MyController"> Hello {{greetMe}}! </div> <script src="http://code.angularjs.org/snapshot/angular.js"></script> <script> angular.module('myApp', []) .controller('MyController', ['$scope', function ($scope) { $scope.greetMe = 'World'; }]); angular.element(function() { angular.bootstrap(document, ['myApp']); }); </script> </body> </html>
Note that we provided the name of our application module to be loaded into the injector as the second parameter of the angular.bootstrap
function. Notice that angular.bootstrap
will not create modules on the fly. You must create any custom modules before you pass them as a parameter.
You should call angular.bootstrap()
after you've loaded or defined your modules. You cannot add controllers, services, directives, etc after an application bootstraps.
This is the sequence that your code should follow:
-
After the page and all of the code is loaded, find the root element of your AngularJS application, which is typically the root of the document.
-
Call
angular.bootstrap
to compile the element into an executable, bi-directionally bound application.
Things to keep in mind
There are a few things to keep in mind regardless of automatic or manual bootstrapping:
- While it's possible to bootstrap more than one AngularJS application per page, we don't actively test against this scenario. It's possible that you'll run into problems, especially with complex apps, so caution is advised.
- Do not bootstrap your app on an element with a directive that uses transclusion, such as
ngIf
,ngInclude
andngView
. Doing this misplaces the app$rootElement
and the app's injector, causing animations to stop working and making the injector inaccessible from outside the app.
Deferred Bootstrap
This feature enables tools like Batarang and test runners to hook into angular's bootstrap process and sneak in more modules into the DI registry which can replace or augment DI services for the purpose of instrumentation or mocking out heavy dependencies.
If window.name
contains prefix NG_DEFER_BOOTSTRAP!
when angular.bootstrap
is called, the bootstrap process will be paused until angular.resumeBootstrap()
is called.
angular.resumeBootstrap()
takes an optional array of modules that should be added to the original list of modules that the app was about to be bootstrapped with.
© 2010–2018 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://code.angularjs.org/1.6.9/docs/guide/bootstrap