首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有大量控件的窗体,这些控件之间存在交互。比$scope.$watch更干净的方法?

具有大量控件的窗体,这些控件之间存在交互。比$scope.$watch更干净的方法?
EN

Stack Overflow用户
提问于 2016-02-08 09:33:50
回答 2查看 54关注 0票数 0

我正在构建一个angular应用程序,表单有大约15个控件。这是一个金融应用程序。请不要建议分解页面等。

其中一些控件相互依赖。大约有5个输入控件(让我们称它们为源控件),它们中的任何一个都可以改变,并影响其他5个控件中的一个或多个(让我们称它们为dest控件)。我构造它的方式是,我对5个源变量中的每个变量都有一个$scope.$watch,并且在每个watch函数中,我都有一些代码来决定要更新5个dest变量中的哪一个,并对它们进行更新。其中一款手表的示例如下所示。

代码语言:javascript
复制
$scope.$watch('money.price',function(newVal,oldVal) {

    if(newVal != oldVal) {

        if($scope.money.quantity != undefined) {
            updatePrincipal($scope)
            updateFees($scope);
            $scope.money.net = $scope.money.principal + $scope.money.fee 
        }
    }
});

我真的不觉得这很优雅。有没有更好/更干净的方法来做这件事?(表单在未来只会变得更复杂,即多2-3个依赖字段,但不会更多)。

EN

回答 2

Stack Overflow用户

发布于 2016-02-08 11:38:35

假设您的输入控件附加了一个ng-model,我建议您向每个输入表单添加ng-change,您可以使用相同的函数一次更新所有范围绑定

票数 1
EN

Stack Overflow用户

发布于 2016-02-09 03:15:18

利用使用ng-bind指令创建的$watch。

代码语言:javascript
复制
<div ng-bind="getMoneyNet()"></div>

     OR SIMPLY

{{ getMoneyNet() }}

定义函数,而不是在控制器中创建$watch。

代码语言:javascript
复制
 $scope.getMoneyNet = function() {
     if ($scope.money.quantity != undefined) {
        updatePrincipal($scope)
        updateFees($scope);
        $scope.money.net = $scope.money.principal + $scope.money.fee 
     };
     return $scope.money.net;
 };

然后,在每个摘要周期中,由ng-bind指令创建的$watch计算money.net的值,并根据需要更新DOM。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35261299

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档