javascript - 为什么解析方法没有向 Controller 返回任何数据?

标签 javascript angularjs ngroute

我正在关注 youtube 的本教程并试图获取解析方法 getposts进入联系 Controller 。我不知道为什么它没有返回任何值。

有人可以告诉我我在这里做错了什么吗?我在 stackoverflow 上花了大约一个小时,但没有希望:(

var app = angular.module('simpleApp', ['ngRoute', 'ngSanitize']);

app.config(['$routeProvider', function($routeProvider){
  $routeProvider
  .when('/', {
    templateUrl: './partials/home.html'
  })
  .when('/contact', {
    controller: "contactController",
    controllerAs: "contactCtrl",
    templateUrl: './partials/contact.html',
    resolve:{
      getposts: function($http) {
        return $http.get('https://jsonplaceholder.typicode.com/comments/1')
                    .then(function(response) {
                      // console.log(response.data) returns api data
                        return response.data;
        })
      } 
    }
  }).controller('contactController', ['$scope', '$http', function($scope, $http, getposts){

  vm = this;

  console.log(getposts); // not getting response.data from getposts

  vm.posts = getposts;

}])

// contact.html
<div>
  <div class="row">
    dfgdfg
    <div class="col-lg-6">
      {{ posts }}
    </div>
  </div>
</div>

问题 1:如果我删除这两行

controller: "contactController",
controllerAs:"contactCtrl"

并添加 ng-controller="contactController"在主分区 contact.html我收到错误

Error: [$injector:unpr] Unknown provider: getpostsProvider <- getposts <- contactController

问题2:如果添加了这些controller和controllerAs行并且ng-controller="contactController"从 View 中删除然后我需要添加 $scope 将帖子输出到 View 。如果我这样做vm.posts = getposts;它不在 View 中显示 json 响应。哦,该死,我很困惑。

最佳答案

基本上,您错过了在 Controller DI 数组的内联数组注释中注入(inject) getPosts

controller('contactController', [
   '$scope', '$http', 'getposts', //<-- you missed to inject here
      function($scope, $http, getposts){

关于javascript - 为什么解析方法没有向 Controller 返回任何数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50455445/

相关文章:

javascript - jquery-ui-map 在点击事件上添加标记

javascript - 使用 JavaScript 设置的值不会保留在回发中

javascript - Chrome/Opera 闪烁绘画问题

javascript - 在 AngularJS 中选择框更改时动态更新跨度内部 html

javascript - AngularJS/jQuery : changing text in span doesn't fire resize event

AngularJS:$route 到底是如何工作的?

javascript - 无法使用 Protractor 定位 svg 类

javascript - document.getElementById onclick 每次页面加载只工作一次

javascript - AngularJS 路由加载错误

javascript - Angular 应用程序未在刷新页面上加载 CSS 和 JS?