javascript - 带有外部 JSON 文件的 ionic 框架

标签 javascript json angularjs ionic-framework

我有一个不知道如何解决的问题,我有一个 IONIC 选项卡模板,想添加一个要显示的外部 JSON 文件,而不是默认显示的模板好友列表。

这是我的 app.js 文件

.state('tab.friends', {
      url: '/friends',
      views: {
        'tab-friends': {
          templateUrl: 'templates/tab-friends.html',
          controller: 'FriendsCtrl'
        }
      }
    })
    .state('tab.friend-detail', {
      url: '/friends/:friendId',
      views: {
        'tab-friends': {
          templateUrl: 'templates/friend-detail.html',
          controller: 'FriendDetailCtrl'
        }
      }
    })

这是我的 controllers.js 文件

.controller('FriendsCtrl', function($scope, Friends) {
  $scope.friends = Friends.all();
})

.controller('FriendDetailCtrl', function($scope, $stateParams, Friends) {
  $scope.friend = Friends.get($stateParams.friendId);
})

这是我的 services.js 文件,它访问一个 JSON 文件:

.factory('Friends', function($http) {
var friends = [];
  return {
    all: function(){
      return $http.get("http://yanupla.com/apps/ligajaguares/equipos.json").then(function(response){
        friends = response.data;
        console.log(friends);
        return friends;
      });
    },
    get: function(friendId) {
       for (var i = 0; i < friends.length; i++) {
        if (friends[i].id === parseInt(friendId)) {
          return friends[i];
        }
      }
      return null;
    }
  }
});

最后是我的 tabs-friends.hm 模板:

<ion-view view-title="Friends">
  <ion-content>
    <ion-list>
      <ion-item class="item-remove-animate item-avatar item-icon-right" ng-repeat="friend in friends" type="item-text-wrap" href="#/tab/friends/{{friend.id}}">
        <!--img ng-src="{{chat.face}}"-->
        <h2>{{friend.name}}</h2>
        <p>{{friend.bio}}</p>
      </ion-item>
    </ion-list>
  </ion-content>
</ion-view>

我可以使用 console.log 在我的浏览器中看到 JSON 文件对象,但我在模板正文中看不到任何其他内容,只有“ friend ”标题。

这里缺少什么?

最佳答案

我猜想 Angular 正在访问 $scope.friends 而它仍然是一个 promise 。您是否尝试过使用 .state-definition 中的 resolve 语句解析变量?

app.js 应该看起来像这样:

.state('tab.friends', {
  url: '/friends',
  views: {
    'tab-friends': {
      templateUrl: 'templates/tab-friends.html',
      controller: 'FriendsCtrl',
      resolve: {
        allfriends: function(Friends) {
          return Friends.all(); }
      }
    }
  }
})

Controller 将是:

.controller('FriendsCtrl', function($scope, allfriends) {
  $scope.friends = allfriends;
})

我认为您需要使用 $q 来正确解析,因此服务需要如下所示:

.factory('Friends', function($http, $q) {
var friends = [];
  return {
    all: function(){
      var dfd = $q.defer();
      $http.get("http://yanupla.com/apps/ligajaguares/equipos.json").then(function(response){
        friends = response.data;
        console.log(friends);
        dfd.resolve(friends);
      });
      return dfd.promise;
    },
    get: function(friendId) {
       for (var i = 0; i < friends.length; i++) {
        if (friends[i].id === parseInt(friendId)) {
          return friends[i];
        }
      }
      return null;
    }
  }
});

有关这方面的更多信息,我建议阅读 ionic 中的这个公式:http://learn.ionicframework.com/formulas/data-the-right-way/

此外,这对我理解 promise 的概念有很大帮助: http://andyshora.com/promises-angularjs-explained-as-cartoon.html

关于javascript - 带有外部 JSON 文件的 ionic 框架,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28719939/

相关文章:

javascript - 合并/替换 Javascript 数组

json - 为什么 ReSTLet 无法注册 JSON 转换器?

angularjs - 带有 Angular CLI 和实时重新加载的 ASP.NET Core

javascript - 在元素中禁用 javascript

javascript - 使用 .fill() 将 .push() 值传递给 JavaScript 数组 (n) 次?

c++ - 我无法弄清楚 "undefined reference to Winmain@16 error"

javascript - 将 Javascript 对象转换为数组

javascript - 使用ng-change时如何修改Angular js中的dom属性?

angularjs - 无法处理混合应用程序中的后退按钮导航问题

javascript - 覆盖浏览器中的快捷键