如何使用指令中的方法更新控制器作用域中的变量?
我用的是:Dropzone.js和angular-dropzone.js。
Dropzone的方法之一是.getQueuedFiles()
。我想使用这个方法来更新控制器作用域中的变量,但是它不起作用。我希望能够更新控制器作用域,这样我就可以显示和隐藏内容,并将文件数传递到表单的下一步。
这是角度:
.controller('ImagesCtrl', function($scope) {
$scope.queuedFiles = 0;
$scope.dropzoneConfig = {
init: function() {
this.on("addedfile", function(file) {
$scope.queuedFiles = $scope.dropzone.getQueuedFiles().length;
});
}
};
})
下面是html:
<form class="dropzone clear"
method="post"
enctype="multipart/form-data"
ng-dropzone
dropzone="dropzone"
dropzone-config="dropzoneConfig">
</form>
<div>Queued Files: {{queuedFiles}}</div>
发布于 2015-03-20 14:28:52
这是正确的代码
var app = angular.module('myApp', ['ui.router', 'myApp.controllers']).
config(['$stateProvider', '$urlRouterProvider',
function ($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/');
$stateProvider
.state('app', {
url: '/',
templateUrl: 'admin.html',
onEnter: function ($stateParams) {
console.log("Entered Admin route");
}
//controller: 'myController'
})
.state('sitebinding', {
url: '/sitebinding',
templateUrl: 'sitebinding.html'
})
.state('scrum', {
url: '/scrum',
templateUrl: 'scrum.html'
});
}
]);
angular.module('myApp.controllers', []).
controller('myController', function ($scope) {
$scope.models = {
helloAngular: 'I work!'
};
$scope.$on('$stateChangeStart', function (evt, toState, toParams, fromState, fromParams) {
console.log('In state change start');
})
});
这就是问题所在:当您第二次编写angular.module('myApp',[])指定依赖项来定义控制器时,您将覆盖原始模块。
如果要向现有模块添加新内容,则不需要传递依赖项数组
angular.module('myModule').controller('MyCtrl',函数..。
https://stackoverflow.com/questions/29174493
复制相似问题