Angular.js、hammer.js、トップコートを使用してモバイルWebアプリを作成しようとしています。
次のようなJsonファイルのデータを表示するのに問題があります。
{
"version": "1",
"artists": {
"artist1": {
"name": "artist1name",
"jpeg": "../img/artist/artist1.jpg",
"albums": {
"album1": {
"type": "cd",
"title": "titlealbum1",
"subtitle": "subtitlealbum1",
"jpeg": "../img/album1.jpg",
"price": "12.00",
"anystring1": "anystring1album1",
"anystring2": "anystring2album1"
},
"album2": [{
"type": "cd",
"title": "titlealbum2",
"subtitle": "subtitlealbum2",
"jpeg": "../img/album2.jpg",
"price": "12.00",
"anystring1": "anystring1album2",
"anystring2": "anystring2album2"
}],
"album3": [{
"type": "cd",
"title": "titlealbum3",
"subtitle": "subtitlealbum3",
"jpeg": "../img/album3.jpg",
"price": "13.00",
"anystring1": "anystring1album3",
"anystring2": "anystring2album3"
}]
}
},
"artist2": {
"name": "artist2name",
"jpeg": "../img/artist/artist2.jpg",
私のjsファイルは次のようなものです:
angular.module('list', [])
function ListCtrl ($scope, $http) {
$http({method: 'GET', url: 'json/json_price_1.json'}).success(function(data)
{
$scope.artists = data.artists; // response data
$scope.albums = data.artists.albums; /this is where im getting trouble
});
};
私のHTMLファイルは次のようなものです。
<body ng-app="list">
<h3>Titulos</h3>
<div ng-controller="ListCtrl">
<ul ng-repeat="artist in artists">
<li >{{artist.name}}</li>
</ul>
</div>
<div ng-controller="ListCtrl">
<ul ng-repeat="album in albums">
<li >{{album.title}}</li> //not working here.
</ul>
</div>
すべてのアルバムを表示し、ユーザーが特定のアーティストを選択した場合、それらのアルバムをフィルタリングします。ここでの質問は、このネストされたjsonでどのように選択するかです。ところで、artist.nameは正しく表示されています。
2番目の質問は、これらのアーティストをテキストフィールドでどのようにフィルター処理するかです。
私は次のようなものを提案します:
$http({method: 'GET', url: 'json/json_price_1.json'}).success(function(data) {
$scope.artists = [];
angular.forEach(data.artists, function(value, key) {
$scope.artists.Push(value);
});
$scope.isVisible = function(name){
return true;// return false to hide this artist's albums
};
});
その後:
<div ng-controller="ListCtrl">
<ul>
<li ng-repeat="artist in artists">{{artist.name}}</li>
</ul>
<ul ng-repeat="artist in artists" ng-show="isVisible(artist.name)">
<li ng-repeat="album in artist.albums">{{album.title}}</li>
</ul>
</div>
すべての問題はJSONから始まります。 JSONを単純化し、それぞれのArtist
とAlbum
をObjectに、Artists
とAlbums
のオブジェクト配列を作成することをお勧めします。
これを試してください:
{
"version": "1",
"artists": [
{
"name": "artist1name",
"jpeg": "../img/artist/artist1.jpg",
"albums": [
{
"type": "cd",
"title": "titlealbum1",
"subtitle": "subtitlealbum1",
"jpeg": "../img/album1.jpg",
"price": "12.00",
"anystring1": "anystring1album1",
"anystring2": "anystring2album1"
},
{
"type": "cd",
"title": "titlealbum2",
"subtitle": "subtitlealbum2",
"jpeg": "../img/album2.jpg",
"price": "12.00",
"anystring1": "anystring1album2",
"anystring2": "anystring2album2"
},
{
"type": "cd",
"title": "titlealbum3",
"subtitle": "subtitlealbum3",
"jpeg": "../img/album3.jpg",
"price": "13.00",
"anystring1": "anystring1album3",
"anystring2": "anystring2album3"
}
]
},
{
"name": "artist2name",
"jpeg": "../img/artist/artist2.jpg",
"albums": []
}
]
}
私の例のように、配列は空にすることができます(artist2にはアルバムが割り当てられていません)。
ListCtrl
にも間違った割り当てがあり、正しいArtist
がわかるまでアルバムを割り当てて表示することはできません。すべてのアーティストのすべてのアルバムを表示するには、すべてのアーティストを繰り返し処理する必要があります。
コントローラーの例:
angular.module('list', []);
function ListCtrl($scope, $http) {
$http({
method: 'GET',
url: 'json_price_1.json'
}).success(function(data) {
$scope.artists = data.artists; // response data
$scope.albums = [];
angular.forEach(data.artists, function(artist, index) {
angular.forEach(artist.albums, function(album, index){
$scope.albums.Push(album);
});
});
});
}
Jessieの例に基づいて修正されたPlunkrは次のとおりです。 http://plnkr.co/edit/zkUqrPjlDYhVeNEZY1YR?p=preview
チェック Plunkerリンク
「このネストされたjsonでどのように選択しますか?」という質問への回答
$.each(data.artists, function(index, element){
$.each(this.albums, function(index, element){
$scope.albums.Push(element);
});
});
「これらのアーティストをテキストフィールドでフィルタリングするにはどうすればよいですか」という質問への回答
<input ng-model="searchText.artistName">
<ul ng-repeat="album in albums | filter:searchText">
<li>{{album.title}}</li>
</ul>
<ul ng-repeat="artist in artists">
<li>
<p>{{artist.name}}</p>
<ul ng-repeat="(key,val) in artist.albums">
<li>{{key}} - {{val}}</li>
</ul>
</li>
</ul>