我正在尝试将 jQuery 插件(Plupload)与 AngularJS 一起使用。我创建了一个指令,它将成为我的文件上传“小部件”。该指令如下所示(链接函数中的代码是Plupload 站点上示例的一个非常简化的版本):
.directive('myFileUpload', function () {
return {
restrict: 'E',
replace: true,
link: function(scope, element, attrs) {
scope.uploaderProperties = {
runtimes : 'html5,flash,html4',
url : 'media/upload',
max_file_size : '10mb',
container: 'fileUploadContainer',
drop_element: 'fileUploadDropArea'
};
scope.uploader = new plupload.Uploader(scope.uploaderProperties);
scope.uploader.init();
scope.uploader.bind('FilesAdded', function(up, files) {
scope.$apply();
});
},
templateUrl: 'upload.html'
};
});
我的 upload.html 文件如下所示:
<div id="{{uploaderProperties.container}}">
<div id="{{uploaderProperties.drop_element}}" style="border: 1px black dashed;">Drop files here<br><br><br></div>
Files to upload:<br>
<div ng-repeat="currFile in uploader.files">{{currFile.name}} ({{currFile.size}}) </div>
<br><br>
<!-- for debugging -->
{{uploader.files}}
<br><br>
</div>
当我在页面上包含带有<my-file-upload>
元素的指令时,所有数据绑定都会正确发生。问题是,在scope.uploader.init();
运行时,id 尚未插入 DOM,因此 Plupload 抱怨并中断,因为它无法选择这些元素。如果我只是在模板中硬编码fileUploadContainer
和fileUploadDropArea
id,它工作得很好。但是,我真的很想在一个地方定义这些 id。
那么,在链接模板后,有什么方法可以init()
在上传器上运行?我考虑过$timeout
在它运行时使用延迟,但这对我来说似乎是一个很大的黑客攻击。有没有更正确的方法来做到这一点?
更新
我把它包init()
成$timeout
这样
$timeout(function() {
scope.uploader.init();
}, 2000);
只是为了确保它会按照我的想法运行,而且果然,随着这个延迟,插件可以正确设置并正常工作。但是,我不想依赖$timeout
. 如果在scope.uploader.init();
链接模板后我可以调用某种方法,那么一切都应该正常。有人知道这样做的好方法吗?