uiElement class
The uiElement class is a direct successor of the uiClass library.
When creating a new component, use the uiElement class as a direct parent, if your component will be the last in the components hierarchy chain.
uiElement source code is <Magento_Ui_module_dir>/view/base/web/js/lib/core/element/element.js, in the Magento Open Source GitHub repository: app/code/Magento/Ui/view/base/web/js/lib/core/element/element.js.
Commonly used methods
- The - initLinks()method implements component communication by using- links.js.- initLinks()introduces processing of the- exports,- imports,- linksand- listensproperties.
- The - initObservable()method allows you to declare observable variables within the same instance.- Example: Copied to your clipboardinitObservable: function () {this._super();this.track('childTemplate')this.observe(['%myVariable1%','%myVariable2%']);return this;}- where: - the - observe()method is a wrapper for the- ko.observable()and- ko.observableArray()methods. It converts the properties of the current method into the observable properties.- observe([{Boolean} isTracked,] {String|Array|Object} listOfProperties):- isTracked-- {Boolean}, optional, - defines access usage: whether to use observable properties (- isTracked = false) or property accessors (- isTracked = true).
- listOfProperties-- {String}is treated as space-separated list of properties' names. Initial values will be used from current instance (when corresponding property exist).
- listOfProperties-- {Array}a list of properties' names. Initial values will be used from current instance (when corresponding property exist).
- listOfProperties-- {Object}a list of properties' names. Initial values will be used from this object.
 
- the - track(listOfProperties)method is equal to- observe(true, listOfProperties).- The main difference between - observe()and- track()is that- observe()is mainly used without first boolean argument. So it really converts properties to observable functions. It changes how property can be accessed. Otherwise- track()uses property accessors. So property access remains the same.- Example: Copied to your clipboardthis.observable = 1;this.observe('observable');this.observable(2); // setterthis.observable(); // getterthis.trackable = 1;this.track('trackable');this.trackable = 2; // setterthis.trackable; // getter
 
- The - initModules()method initializes external UI components' instances and links them to local variables. This method works with the- modulessection of the configuration, where we define the name of the external instance and the local variable. The- modulessection is an object where each key is the variable's name and each value is the instance's name. A developer does not need to be concerned with the instantiation of the module (external instance), because the- initModules()method will resolve the variable when the instance is instantiated.- Example: Copied to your clipboard// Config, where the `modules` property is declareddefaults: {modules: {'%myProperty%': '%linkToTheComponent%'}}
- The - getTemplate()method returns a file path to UI component's template.
- The - hasTemplate()method verifies that the- templateproperty was specified in the instance configuration.
