不UDPATE型号我不明白为什么,如果我加入更多的元素,以我的数组一个指令的控制器内,不会在视图显示和最差的是,如果打印我的模型,它不显示最新元素的加入可以指令
以下是我定义我的指令
angular.module('example',[]);
angular.module('example').directive('documentUpload', function() {
function link($scope, $element, attrs, ngModelCtrl) {
$element.find('input[type="file"]').on('change', function(){
$scope.submitFile(this);
});
}
return {
restrict: 'E',
templateUrl: 'document-upload.html',
controller: function($scope,$element) {
$scope.files = [{ name : "blah", src: "blah" }];
$scope.submitFile = function(file,container) {
var currentFile = file.files[0];
var reader = new FileReader();
reader.onloadend = function(){
$scope.files.push({
name: currentFile.name,
src : reader.result
});
console.log($scope.files);
console.log($scope.example);
}
reader.readAsDataURL(currentFile);
};
},
alias: 'document',
link: link
}
}).directive('imageFiles', function($compile) {
return {
scope: {
file: "="
},
template: '<img ng-model="file" ng-src="file.src" alt="file.name" class="img-responsive"/>'
}
});
如果我想看看在视图模型没有显示最新加入的元素,
<div class="row">
<pre>{{ files }}</pre>
<div class="col-lg-12">
<form method="POST" enctype="multipart/form-data" ng-submit="submit(document)">
<input type="file" name="file" ng-model="document.file"/>
</form>
</div>
<div class="row" ng-repeat="file in files" image-files>
这里有一个现场Example
你的功能改变它永远不会被调用。我会考虑调用该函数的更好方法。 – ribsies 2015-03-02 23:03:09
这是真的没有在运行的例子让我固定的(而且是工作在我的固定环境 – Jorge 2015-03-02 23:08:53
..现在是触发的方式 – Jorge 2015-03-02 23:11:17