Home > Web Front-end > JS Tutorial > How to Integrate AngularJS Controls with Legacy Code Requiring DOM Window Callbacks?

How to Integrate AngularJS Controls with Legacy Code Requiring DOM Window Callbacks?

Barbara Streisand
Release: 2024-10-19 10:34:29
Original
239 people have browsed it

How to Integrate AngularJS Controls with Legacy Code Requiring DOM Window Callbacks?

Call AngularJS from Legacy Code

Problem:
You need to integrate AngularJS controls with a legacy Flex application that requires callbacks attached to the DOM window.

Solution:

To dispatch events that AngularJS controllers can listen to from outside the framework, follow these steps:

  1. Get the Scope and Injector:

    • Use angular.element(domElement).scope() to obtain the current scope for the HTML element that is used to update the AngularJS application.
    • Use angular.element(domElement).injector() to access the current app injector.
  2. Obtain the AngularJS Service:

    • From the injector, obtain the AngularJS service that you wish to update.
  3. Invoke AngularJS Functions:

    • Within AngularJS, wrap any updates to the model or method invocations on the scope in $apply(function(){ ... }) to ensure proper change propagation.

Example Usage:

// Get the AngularJS scope and service
var scope = angular.element(document.getElementsByTagName('body')[0]).scope();
var service = scope.injector().get('myService');

// Invoke an AngularJS method
scope.$apply(function () {
  service.update();
});
Copy after login

Additional Notes:

  • Changes to the AngularJS model or scope method invocations must be wrapped in $apply().
  • You can use angular.element(domElement).controller() to access the AngularJS controller associated with the HTML element.

The above is the detailed content of How to Integrate AngularJS Controls with Legacy Code Requiring DOM Window Callbacks?. For more information, please follow other related articles on the PHP Chinese website!

source:php
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template