Getter & setter support with ng-model in AngularJs

后端 未结 2 1350
遥遥无期
遥遥无期 2021-02-20 02:52

I am trying to get getter/setter support for ng-model by implementing a directive that will take care of getting and setting the values to/from the view/model. I am almost there

相关标签:
2条回答
  • 2021-02-20 03:10

    NOTE AngularJs 1.3 now supports Getter/Setter for ng-model. Refer to http://docs.angularjs.org/api/ng/directive/ngModelOptions for more information.


    I could break the infinite loop with extra calls to

    ngModelCtrl.$setViewValue()
    

    and

    ngModelCtrl.$render()
    

    in the event handlers. Not sure if it's the best way to do it though.

    See fiddle: http://jsfiddle.net/BDyAs/12/

    EDIT:

    I improved the code even more in

    http://jsfiddle.net/BDyAs/15/

    by separating the directive in separate ones for the getter and the setter.

    0 讨论(0)
  • 2021-02-20 03:24

    I think the question about breaking the digest loop has been answered. Here is a different, much cleaner approach to the same problem that doesn't involve $watch.

    When you don't need to support legacy browsers, use ECMAScript 5 accessors.

    Just add a property to your angular controller:

    Object.defineProperty(
        $scope, 
        "accessorWrappedMyValue",            
        {
            get : function() { return $scope.myValue; },  
            set : function(newValue) { 
                      $scope.myValue = newValue; 
                      $scope.myDerivedValue = $scope.myValue * 2;
                  },
            configurable: true
        });
    

    Now all you need to do is reference accessorWrappedMyValue from ng-model like so:

    <input type="text" ng-model="accessorWrappedMyValue" />
    

    Further reading

    This blog has a nice introduction to ES5 accessors.

    Use this feature matrix to decide whether you can go with ES5 or not. The interesting lines are "Getter / Setter in property initializer" and "Object.defineProperty".

    0 讨论(0)
提交回复
热议问题