如何在自己的文件中定义模态控制器?
Posted
技术标签:
【中文标题】如何在自己的文件中定义模态控制器?【英文标题】:How to define modal controllers in their own file? 【发布时间】:2014-02-17 22:39:08 【问题描述】:我的 Angular 应用程序有许多模态,我有 AngularUI 来提供模态指令。
http://angular-ui.github.io/bootstrap/
到目前为止,我有几个主要的控制器,这些都在 app.js 文件中作为路由。
$routeProvider.when '/dashboard', templateUrl: '/templates/dashboard/dashboard.html', controller: 'DashboardController'
$routeProvider.when '/dataset/:panel_id', templateUrl: '/templates/dataset/dataset.html', controller: 'DatasetController'
$routeProvider.when '/batches/:panel_id', templateUrl: '/templates/design/design.html', controller: 'PanelController'
这很好用。
然后我创建了一个调用模态的函数,模态有一个ConfigureModalCtrl的实例控制器。我最初在调用控制器文件的底部有这个,它工作正常。
$scope.invokeConfigureModal = (assay_id) ->
$scope.assay_id = assay_id
$scope.primer3 = $scope.getPrimer(assay_id)
modalInstance = $modal.open(
templateUrl: '/templates/configure_modal/configure_modal.html'
controller: ConfigureModalCtrl
windowClass: 'configure-dialog'
resolve:
primer3: ->
$scope.primer3
)
modalInstance.result.then ((primer3) ->
$scope.primer3 = primer3
return
), ->
return
现在我已经将模态实例控制器移动到它自己的文件中,但是调用函数找不到它。
angular.module('assaypipelineApp').controller "ConfigureModalCtrl", ($scope, $modalInstance, primer3) ->
$scope.primer3 = primer3['data']
$scope.ok = ->
$modalInstance.close $scope.primer3
return
$scope.cancel = ->
$modalInstance.dismiss "cancel"
serverErrorHandler = ->
alert("There was a server error, please reload the page and try again.")
错误信息
Error: Unknown provider: ConfigureModalCtrlProvider <- ConfigureModalCtrl
类似的问题,但没有解决我的问题。 How to create separate AngularJS controller files?
那么我该如何解决这个问题,为什么其他(非模态实例)控制器不会发生这种情况?是因为它们在路线中被命名了吗?
也欢迎任何关于编码风格的建议......感谢阅读本文。
【问题讨论】:
【参考方案1】:尝试将控制器作为字符串——我遇到了类似的问题。
controller: 'ConfigureModalCtrl'
【讨论】:
以上是关于如何在自己的文件中定义模态控制器?的主要内容,如果未能解决你的问题,请参考以下文章
如何从自己的子视图控制器中关闭模态 uitabbarcontroller