我的网页上有多个flow-btn
元素。有一个项目列表,用户可以直接将单个文件上传到(单独)或,他们可以选择上传多个文件,这些文件将自动填充列表。一切都在flow-init
内。
有点像这个伪代码示例:
<div flow-init>
<div flow-btn>Upload multiple images to fill the list</div>
<h3>The list</h3>
<ul>
<li ng-repeat="item in items">
<div flow-btn flow-single-file>Upload an image for this item</div>
<img flow-img="item.flowFile">
</li>
</ul>
</div>
我需要确定列表中使用了哪个flow-btn
,以便我可以在正确的位置显示上传的图像缩略图。基本上我认为我想从流事件中访问item
。
注意:列表循环数据由其他数据定义,因此我不能只通过$flow.files
来创建我的列表。
我该怎么做?
我应该为每个循环项创建一个新的flow-init
实例吗?矫枉过正?
编辑:或者,也许我可以通过编程方式从我的控制器中打开多个flow-btn
,而不是每个项目都有flow-btn
?在这种情况下,我可以存储控制器中的当前项目。
答案 0 :(得分:0)
修改。 08.2015 强> 我在firefox下再次检查了这个,输入元素似乎不是隐藏在event.srcElement中,而是在event.originalTarget中。我已更新代码和plnkr。
好吧,你可能知道ng-flow提供了一些事件。对于那些事件,您可以传递函数并使用$ event对象注入它们,该对象引用了您单击的特定按钮。在您的情况下,您可以监听 flow-files-submitted 并基于 $ event.srcElement 执行以下相应的操作:
HTML
<div flow-init flow-files-submitted='handleUpload($files, $event, $flow)'>
<div flow-btn>Upload multiple images to fill the list</div>
<h3>The list</h3>
<ul>
<li ng-repeat="item in items">
<div flow-btn flow-single-file>Upload an image for this item</div>
<img flow-img="item.photo" ng-if='item.photo'>
</li>
</ul>
</div>
JS
$scope.handleUpload = function($files, $event, $flow) {
if(($event.srcElement !== undefined)&&($event.srcElement !== null))
var input = angular.element($event.srcElement)
else
var input = angular.element($event.originalTarget)
if (input.scope().item) {
if(input.scope().item.photo) {
input.scope().item.photo.cancel();
}
input.scope().item.photo = $files[0];
} else {
for(var i = 0; i < $files.length; i++) {
$scope.items.push({photo: $files[i]});
}
}
};