gpt4 book ai didi

javascript - FileReader 和 $scope.$watch 的 AngularJS 问题?

转载 作者:行者123 更新时间:2023-11-30 08:39:21 25 4
gpt4 key购买 nike

我有一个奇怪的(至少对我来说)希望有人能够提供帮助。也许我只是在以错误的方式思考这个问题。尝试在 javascript 中处理文件对我来说是全新的。

我有一个指令,其模板如下所示:

<input type="file" ng-file-select ng-model="files">
<button ng-click="onFileSelect()">Upload</button>

在指令的 Controller 中,我这样做:

$scope.onFileSelect = function() {
reader = new FileReader();
reader.onload = function() {
$scope.file_contents = this.result;
};
reader.readAsArrayBuffer($scope.files[0]);

//debugger;
$scope.$watch('file_contents',function(file_contents) {
console.log(file_contents);
if (angular.isDefined(file_contents)) {
... bunch of code attempting to deal with file_contents ...
}
});
};

我选择一个文件,然后单击“上传”按钮。 (file_contents) 的 console.log 未定义。只有当我第二次点击按钮时,它才有值。

如果我取消对调试器的注释,$scope.file_contents 在我检查它时就会有一个值。

因此,file_contents 需要一些时间来设置(这是预期的),但 $watch 似乎从来没有注意到?这有什么奇怪的原因吗? $watch 不适用于 FileReader 对象吗?

编辑 1:

好的。这里有更多信息。按照 PSL 的建议,我现在有了这样的代码:

$scope.onFileSelect = function() {
reader = new FileReader();
reader.onload = function() {
file_contents = this.result;
upload_file($scope.files[0],file_contents);
};
reader.readAsArrayBuffer($scope.files[0]);
};

upload_file = function(file,file_contents) {
<lots of cool file_contents-y stuff>
};

为什么我仍然收到 $digest 错误?我再也没有$watches了。我不对 upload_file 中的 $scope 做任何事情。 $digest 错误也没有堆栈跟踪来帮助我。我得到的是:

Error: [$rootScope:inprog] $digest already in progress
http://errors.angularjs.org/1.3.0-beta.10/$rootScope/inprog?p0=%24digest

这是做什么的?

最佳答案

Watch 似乎从来没有注意到,因为您正在更新 Angular 上下文之外的范围。您需要使用 scope.$apply() 或任何其他方式(例如在 onload 异步函数中使用 $timeout 等)手动调用摘要循环。最好将 watch 移到 onFileSelect 方法之外,否则每次上传点击都会继续添加 watch。

尝试:

$scope.onFileSelect = function() {
reader = new FileReader();
reader.onload = function() {
$scope.file_contents = this.result;
$scope.$apply(); /<-- here
};
reader.readAsArrayBuffer($scope.files[0]);

};

$scope.$watch('file_contents',function(file_contents) {
console.log(file_contents);
if (angular.isDefined(file_contents)) {
... bunch of code attempting to deal with file_contents ...
}
});

不确定完整的场景,但您可能甚至不需要创建一个 watch,只需将文件处理包装在一个方法中并从 onload 调用该方法并执行范围。$apply( ).你的 watch 第一次执行的原因是因为它总是在设置后运行以启动脏检查,到那时 async onload 还没有在范围上设置任何值,即使它设置了摘要周期也不是意识到这一点。

关于javascript - FileReader 和 $scope.$watch 的 AngularJS 问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28143421/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com