如何在Angularjs控制器之外操作模型?

时间:2013-10-15 23:22:50

标签: javascript jquery angularjs

我有一个我在模块中注册的控制器。然而,我想要做的是访问Angular之外的$ scope,以便我可以更改模型。例如,我想做以下事情:

var sentboxCtrl = function ($scope){

    $scope.sent = Sent;
    $scope.deleteIcon = deleteIconSource;
    $scope.flagIcon = flagIconSource;
    $scope.attachmentIcon = attachmentIconSource;

    for(var i = 0; i < $scope.sent.length ; i ++)
    {
        $scope.sent[i]['checked'] = false;
    }

    $scope.delete = function(element)
    {
        for(var i = 0; i < $scope.sent.length; i ++)
        {
            if($scope.sent[i].id == element.id)
            {
                $scope.sent.splice(i,1);
            }
        }

    }

    $scope.deleteChecked = function()
    {
        for(var i = 0; i < $scope.sent.length; i++)
        {
            if($scope.sent[i].checked)
            {
                $scope.sent.splice(i,1);

                // We must account for sent.length changing
                // after splicing so we need to decrement to
                // account for that.
                i --;
            }
        }
    }

    $scope.getModel = function()
    {
        return $scope;
    }

};

我使用sentboxCtrl.getModel返回范围,然后我可以在正常上下文之外操作范围的属性。

我该怎么做?

1 个答案:

答案 0 :(得分:0)

您可以在angular的上下文之外定义一个对象,然后在控制器函数内部,将其值赋给$ scope:

var controllerScope = null;
var sentboxCtrl = function ($scope){
    controllerScope = $scope;
    ...
}

现在您可以访问所有$ scope对象的属性。