Integration

AngularJS Support

The MaskEditTextbox control supports two types of AngularJS support namely,

  • One-way binding
  • Two-way binding

One-way binding refers to the process of applying scope values to all the available properties of the MaskEditTextbox control, but the changes made in MaskEditTextbox control are not reflected or triggered in turn to the scope collection. This kind of binding applies to all the properties of the MaskEditTextbox control.

Two-way binding supports both the processes; it applies the scope values to the MaskEditTextbox properties as well as the changes made in the MaskEditTextbox control also get reflected back and triggered within the AngularJS scope change function.

Apply the plugin and property assigning to the MaskEditTextbox control element through the directive that starts with the letter “e-“.

To know more details about the AngularJS binding, refer to the following link location,

http://help.syncfusion.com/js/angularjs

The following example explains the how to bind data to the MaskEditTextbox control through the Angular Support.

  • html
  • <!DOCTYPE html>
    
    <html xmlns="http://www.w3.org/1999/xhtml" ng-app="TextCtrl">
    
    <head>
    
        <title></title>
    
        <link href="Content/bootstrap.min.css" rel="stylesheet" />
    
        <link href=" http://cdn.syncfusion.com/17.3.0.9/js/web/flat-azure/ej.web.all.min.css" rel="stylesheet" />
    
        <script src="http://cdn.syncfusion.com/js/assets/external/jquery-1.10.2.min.js"></script>
    
        <script src="http://cdn.syncfusion.com/js/assets/external/angular.min.js"></script>  
    
        <script src="http://cdn.syncfusion.com/17.3.0.9/js/web/ej.web.all.min.js"></script>
    
        <script src="http://cdn.syncfusion.com/17.3.0.9/js/web/ej.unobtrusive.min.js"></script>
    
        <script src="http://cdn.syncfusion.com/17.3.0.9/js/ej.widget.angular.min.js"></script>
    
    </head>
    
    <body ng-controller="TextboxCtrl">
    
        <div id="center">
    
            <table cellpadding="10">
    
                <tbody>
    
                    <tr>
    
                        <td>
    
                            <label for="numeric">Numeric</label>
    
                        </td>
    
                        <td>
    
                            <input id="numeric" type="text" ej-numerictextbox e-value="numericValue" />
    
                        </td>
    
                        <td>
    
                            <input type="text" class="input ejinputtext" ng-model="numericValue" />
    
                        </td>
    
                    </tr>
    
                </tbody>
    
            </table>
    
        </div>
    
        <script type="text/javascript">
    
            angular.module('TextCtrl', ['ejangular'])
    
               .controller('TextboxCtrl', function ($scope) {
    
                   $scope.numericValue = 600;
    
               });
    
        </script>
    
    </body>
    
    </html>

    The output of NumericTextbox controls with two-way AngularJS binding is as follows.

    KnockoutJS Support

    KnockoutJS support allows you to bind the HTML elements against any of the available data models. It is of two types.

    • One-way binding
    • Two-way binding

    One-way binding refers to the process of applying observable values to all the available properties of the MaskEditTextbox control, but the changes made in the MaskEditTextbox control are not reflected and triggered in turn to the observable collection. This kind of binding applies to all the properties of the MaskEditTextbox control.

    Two-way binding supports both the processes; it applies the observable values to the MaskEditTextbox control properties as well as the changes made in the MaskEditTextbox control are also reflected back and triggered within the observable collections.

    For more information about the Knockout Binding, refer to the following online documentation in the given link location,

    http://help.syncfusion.com/js/knockoutjs

    The following example explains the how to bind data to the MaskEditTextbox control through Knockout Support that enables and populates data to the MaskEditTextbox control based on the value set to the other MaskEditTextbox control.

  • html
  • <!DOCTYPE html>
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    
    <head>
    
        <title></title>
    
        <link href="Content/bootstrap.min.css" rel="stylesheet" />
    
        <link href=" http://cdn.syncfusion.com/17.3.0.9/js/web/flat-azure/ej.web.all.min.css" rel="stylesheet" />
    
        <script src="http://cdn.syncfusion.com/js/assets/external/jquery-1.10.2.min.js"></script>
    
        <script src="http://cdn.syncfusion.com/js/assets/external/knockout.min.js"></script>
    
        <script src="http://cdn.syncfusion.com/17.3.0.9/js/web/ej.web.all.min.js"></script>
    
        <script src=" http://cdn.syncfusion.com/17.3.0.9/js/web/ej.unobtrusive.min.js "></script>
    
        <script src="http://cdn.syncfusion.com/17.3.0.9/js/ej.widget.ko.min.js"></script>
    
    </head>
    
    <body>
    
        <div id="center">
    
            <table cellpadding="10">
    
                <tbody>
    
                   <tr>
    
    
    
                        <td>
    
    
    
                            <label for="maskedit">Mask Edit</label>
    
    
    
                        </td>
    
    
    
                        <td>
    
    
    
                            <input id="maskedit" type="text" data-bind="ejMaskEdit: { value: maskValue, inputMode: ej.InputMode.Text, maskFormat: '(999)999-9999' }" />
    
    
    
                        </td>
    
    
    
                        <td>
    
    
    
                            <input type="text" class="input ejinputtext" data-bind="value: maskValue" />
    
    
    
                        </td>
    
    
    
                    </tr>
    
    
    
                </tbody>
    
            </table>
    
        </div>
    
        <script type="text/javascript">
    
            var maskObject;
    
            window.viewModel = {
    
                maskValue: ko.observable("")
    
            }
    
            jQuery(function ($) {
    
                ko.applyBindings(viewModel);
    
                maskObject = $("#maskedit").data("ejMaskEdit");
    
            });
    
        </script>
    
    </body>
    
    </html>

    The output of Knockout binding in MaskEditTextbox.