In Angular 1.x, current version, changes made "outside" of the angular are not identified by it, $scope.apply() or $scope.digest() do the job of asking the angular to review their variables in search of external modifications. Note that there in this code example, the function within the apply searches the page structure with the document.getElementById (which is a medium outside the angular), an element that is possibly managed by the angular and alters it.
It is important to warn, that $scope.apply() says at the angle, "Hey, I changed something! Turn around and find out what it was." then it will search across the root of elements managed by the possible changes, which can be quite bad in terms of performance. The $scope.digest() does the same thing, but only from the current scope down.
More information here in the documentation: https://docs.angularjs.org/api/ng/type/$rootScope.Scope#$apply
Just to complement, I cited Angular 1.x because in Angular 2, according to the documentation these changes outside of Cope, will be detected automatically.