5

我正在使用这个控件:http ://blueimp.github.io/jQuery-File-Upload/angularjs.html以角度进行文件上传,一旦文件上传到我的服务器,我返回一个 url 并希望显示它成功回调的客户端。正在使用的插件只是一个普通的 jquery 文件上传,但我正在使用一个 angular 指令包装器。

这是我定义回调的方式:

$scope.options = {
    url: '/api/Client/',
    type: 'PUT',
    done: function (event, data) {
        var scope = angular.element(this).scope();
        scope.test = "doesn't work";
        scope.$apply(function () {
            scope.test = "this doesn't work either";
        });
    }
};

文件上传正常,并且调用了 done 函数但是我无法更新视图。我最初只是尝试更改范围,然后我意识到我需要 $apply() 函数,但这也不起作用。

我也试过

$scope.options = {
    url: '/api/Client/',
    type: 'PUT',
    done: function (event, data) {
        $scope.test = "doesn't work";
        $scope.$apply(function () {
            $scope.test = "this doesn't work either";
        });
    }
};

这也行不通。我不确定它为什么不更新我的视图,并且由于 done 调用只是一个 ajax 成功事件,我看不出这个特定插件如何导致 $scope.$apply 出现任何问题。我正在使用 AngularJs 1.1.5,但我也尝试过 1.0.7 并且遇到了同样的问题。

4

2 回答 2

11

从我的评论中复制以更清楚地说明问题所在:

我设法找出问题所在。当使用他们的示例时,我有一个 ng-controller 的副本(他们的示例嵌套在我的另一个控制器中),即使两者都使用相同的控制器,它似乎只会更新嵌套控制器范围内的任何内容。删除重复的 ng-controller 属性时,一切正常。

于 2014-11-10T13:27:09.717 回答
1

我想我也会加入进来,因为我已经花了一整天的时间来处理这个问题。

确保在您的 HTML 中,将 ng-controller 应用于 div 包装器,而不是 ul 元素。

于 2015-06-11T08:01:09.723 回答