.controller('myCtrl', function($scope,$localstorage,$stateProvider, $urlRouterProvider) {

  $scope.getNews= function(){
  $stateProvider.stat('app.news')
}

});
为什么我收到未知提供者的错误?我已经将依赖项注入(inject)到 Controller 中。

最佳答案

您遇到的问题是,您试图将$ stateProvider添加到 Controller ,而不是添加到app.config()函数。如果查看UI-Router文档,将会看到应该在app.config中对其进行配置,该app.config将在启动 Controller 之前加载。

您可以从 Controller 中的$ state提供程序读取数据,但仅当将其用作服务时才可以读取。这可能是一个令人困惑的区别。我尝试在下面解释。

在Angular中,您可以创建三种类型的服务:提供程序,工厂和服务。有几个差异,对于此答案来说并不是特别重要,但是您可以在此处了解这些差异:AngularJS: Service vs provider vs factory

在这种情况下,重要的是要知道Provider是可以注入(inject)到应用程序的config()函数中的唯一服务类型。通常,提供程序的功能在您的 Controller 中也很有用。例如,您可以配置$ stateProvider路由到您的config()中,但是您可能想在 Controller 中读取当前状态的名称。

现在,这里变得棘手:$ stateProvider是一个提供程序,当将Angular注入(inject)config()时,Angular要求您将其称为$ stateProvider。但是,它也可以用作服务,但是当您将服务注入(inject) Controller 时,您无法指定服务类型。因此,$ stateProvider变为$ state。这与$ get方法的分配方式有关,您可以在此处阅读全部内容:https://github.com/angular/angular.js/wiki/Understanding-Dependency-Injection

因此,如果您要配置路由,请将它们包括在配置中:

myApp.config(function($stateProvider, $urlRouterProvider) { ... })

如果您试图读取有关当前状态的信息,则可以将其注入(inject)到 Controller 中:
myApp.controller('myCtrl', function($state) { ... })

关于javascript - 未知提供者: $stateProviderProvider <- $stateProvider,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/31119896/

10-10 09:08