我有一个这样的json。这是服务器响应。
[
{
"itemId": 1062,
"businessType": "SPORT",
"name": "Modern Martial Arts Vitor Shaolin Brazilian Jiu Jitsu",
"websiteUrl": "http://www.yelp.com/biz/modern-martial-arts-vitor-shaolin-brazilian-jiu-jitsu-new-york",
"rating": 5,
"city": "New York",
"address": "780 8th Ave (b/t 47th St & 48th St) Hell's Kitchen New York NY 10036",
"imageUrl": "http://s3-media3.ak.yelpcdn.com/bphoto/JHk9p_jYX1QpQN4Im-p3jA/ms.jpg",
"source": "Yelp",
"price" :"6 $",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 8227,
"businessType": "SPORT",
"name": "TGA of Bergen County",
"websiteUrl": "http://www.golftga.com/Default.aspx?alias=www.golftga.com/bergencounty",
"city": "Wayne",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"price" :"26 $",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3932,
"businessType": "SPORT",
"name": "Willowbrook Golf Center",
"websiteUrl": "http://www.willowbrookgolfcenter.com",
"city": "North Jersey",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"price" :"36 $",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3918,
"businessType": "SPORT",
"name": "Church Street Boxing Gym & Pouncing Tigers",
"websiteUrl": "http://www.csboxinggym.com/",
"city": "New York City",
"address": "201207 West 42nd Street New York NY 10036 USA",
"source": "Groupon",
"price" :"106 $",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 1100,
"businessType": "SPORT",
"name": "CKO Kickboxing Carroll Gardens",
"websiteUrl": "http://www.yelp.com/biz/cko-kickboxing-carroll-gardens-brooklyn-2",
"rating": 4,
"city": "Brooklyn",
"address": "562 Court St (b/t Hamilton Ave & Garnet St) Carroll Gardens Brooklyn NY 11231",
"imageUrl": "http://s3-media2.ak.yelpcdn.com/bphoto/guwuh08U_tYTyRsjLQIJ-w/ms.jpg",
"source": "Yelp",
"price" :"29$",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 462,
"businessType": "SPORT",
"name": "TITLE Boxing Club",
"websiteUrl": "http://www.titleboxingclub.com",
"city": "Wayne",
"address": "Wayne NJ 07470 USA",
"source": "Groupon",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 474,
"businessType": "SPORT",
"name": "Centercourt Athletic Club of Morristown",
"websiteUrl": "http://www.centercourtclub.com/club/scripts/section/section.asp?CLNK=1&NS=CMT",
"city": "Wayne",
"address": "Wayne NJ 07470 USA",
"source": "Groupon",
"price":"1008 $",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3326,
"businessType": "SPORT",
"name": "Legends Baseball Instruction",
"websiteUrl": "http://www.legendsbaseballinstruction.com",
"city": "North Jersey",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 1104,
"businessType": "SPORT",
"name": "Adirondack Sailing",
"websiteUrl": "http://www.yelp.com/biz/adirondack-sailing-new-york",
"rating": 4,
"city": "New York",
"address": "62 Chelsea Piers New York NY 10011",
"imageUrl": "http://s3-media1.ak.yelpcdn.com/bphoto/FwpUOlPWSpLlEteBGukcpg/ms.jpg",
"source": "Yelp",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Friend",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
}
},
{
"itemId": 1709,
"businessType": "SPORT",
"name": "Manhattan Sailing Club",
"websiteUrl": "http://www.yelp.com/biz/manhattan-sailing-club-new-york",
"rating": 4,
"city": "New York",
"address": "385 S End Ave Ste 6H Battery Park New York NY 10280",
"imageUrl": "http://s3-media1.ak.yelpcdn.com/bphoto/9yvzeSYaKfguvDUzF69xvw/ms.jpg",
"source": "Yelp",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Friend",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
}
},
{
"eventId": 9743,
"description": "PARKING PASSES ONLY Igor Krutoi Gala Concert Tickets",
"event_date": "2015-01-31 00:00:00.0",
"venue_name": "Barclays Center Parking Lots",
"city": "Brooklyn",
"urlpath": "http://www.stubhub.com/parking-passes-only-igor-krutoi-gala-concert-brooklyn-barclays-center-parking-lots-31-1-2015-9004479",
"totalTickets": "0.0",
"title": "PARKING PASSES ONLY Igor Krutoi Gala Concert Tickets",
"ancestorGenreDescriptions": "[All tickets, Concert tickets, Artists H - K, Igor Krutoi Gala Tickets]",
"itemType": "Event",
"category": "Concert",
"source": "Stubhub",
"suggestionCriteria": "following",
"suggestedBy": "FriendSuggest",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
},
"timeLine": "January 31 at 07:01 PM",
"startDate": "2015-01-31 00:00:00.0",
"endDate": "2015-01-31 00:00:00.0",
"address": "Barclays Center Parking Lots\nBrooklyn,New York 11217",
"isBooked": true
}
];
我把它放在ng-repeat中。我waana制作一个过滤器,根据评级(1,2,3,4,5)和价格(0-9; 10 -99,100-999)过滤这些项目。 我不知道如何继续进行。任何帮助?
Plunker Link:http://plnkr.co/edit/8ArGO1OvT7FHIV1ixSEA?p=preview
答案 0 :(得分:1)
首先,JSON中存在价格代表方式的问题。例如,
"price" :6 $;
无效,应列为
"price" :6 ,
有几种价格会发生这种情况。接下来,您可以使用以下
HTML
<div ng-app="myApp" ng-controller='MainCtrl'>
Rating : <select ng-model='filterParams.rating' ng-options='i for i in ratingParams'><option value=''></option></select>
Price : <select ng-model='filterParams.price' ng-options="p.range for p in priceParams"><option value=''></option></select>
<hr/>
<table class="table table-condensed table-striped" >
<thead>
<tr>
<th>Id</th>
<th>Type</th>
<th>Name</th>
<th>Rating</th>
<th>Price</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="j in json | customFilter:filterParams">
<td>{{j.itemId}}</td>
<td>{{j.businessType}}</td>
<td>{{j.name}}</td>
<td>{{j.rating}}</td>
<td>{{j.price}}</td>
</tr>
</tbody>
</table>
</div>
以下Javascript:
var app = angular.module("myApp",[]);
app.filter("customFilter", function(){
return function(items, filterParams){
var filteredItems = [];
if (filterParams) {
angular.forEach(items, function(value){
var matchRating = true, matchPrice = true;
// Ratings filter
if (filterParams.rating){ matchRating = value.rating >= filterParams.rating;}
// Price filter
if (filterParams.price){ matchPrice = value.price >= filterParams.price.lower && value.price <= filterParams.price.upper;}
// If items pass both filter, include them
if (matchRating && matchPrice) {filteredItems.push(value);}
})
}
else {
// If no filters specified
filteredItems = items;
}
return filteredItems;
}
})
app.controller("MainCtrl", function($scope){
$scope.priceParams = [
{range : '0-9', lower: 0, upper:9},
{range : '10-99', lower: 10, upper:999},
{range : '100-999', lower: 100, upper:999}
];
$scope.ratingParams = [1,2,3,4,5];
$scope.json = [
{
"itemId": 1062,
"businessType": "SPORT",
"name": "Modern Martial Arts Vitor Shaolin Brazilian Jiu Jitsu",
"websiteUrl": "http://www.yelp.com/biz/modern-martial-arts-vitor-shaolin-brazilian-jiu-jitsu-new-york",
"rating": 5,
"city": "New York",
"address": "780 8th Ave (b/t 47th St & 48th St) Hell's Kitchen New York NY 10036",
"imageUrl": "http://s3-media3.ak.yelpcdn.com/bphoto/JHk9p_jYX1QpQN4Im-p3jA/ms.jpg",
"source": "Yelp",
"price" : 6,
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 8227,
"businessType": "SPORT",
"name": "TGA of Bergen County",
"websiteUrl": "http://www.golftga.com/Default.aspx?alias=www.golftga.com/bergencounty",
"city": "Wayne",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"price" :26,
"rating" : 4,
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3932,
"businessType": "SPORT",
"name": "Willowbrook Golf Center",
"websiteUrl": "http://www.willowbrookgolfcenter.com",
"city": "North Jersey",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"price" :36,
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3918,
"businessType": "SPORT",
"name": "Church Street Boxing Gym & Pouncing Tigers",
"websiteUrl": "http://www.csboxinggym.com/",
"city": "New York City",
"address": "201207 West 42nd Street New York NY 10036 USA",
"source": "Groupon",
"price" :106 ,
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 1100,
"businessType": "SPORT",
"name": "CKO Kickboxing Carroll Gardens",
"websiteUrl": "http://www.yelp.com/biz/cko-kickboxing-carroll-gardens-brooklyn-2",
"rating": 4,
"city": "Brooklyn",
"address": "562 Court St (b/t Hamilton Ave & Garnet St) Carroll Gardens Brooklyn NY 11231",
"imageUrl": "http://s3-media2.ak.yelpcdn.com/bphoto/guwuh08U_tYTyRsjLQIJ-w/ms.jpg",
"source": "Yelp",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 462,
"businessType": "SPORT",
"name": "TITLE Boxing Club",
"websiteUrl": "http://www.titleboxingclub.com",
"city": "Wayne",
"address": "Wayne NJ 07470 USA",
"source": "Groupon",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 474,
"businessType": "SPORT",
"name": "Centercourt Athletic Club of Morristown",
"websiteUrl": "http://www.centercourtclub.com/club/scripts/section/section.asp?CLNK=1&NS=CMT",
"city": "Wayne",
"address": "Wayne NJ 07470 USA",
"source": "Groupon",
"price":1008,
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 3326,
"businessType": "SPORT",
"name": "Legends Baseball Instruction",
"websiteUrl": "http://www.legendsbaseballinstruction.com",
"city": "North Jersey",
"address": "17 North Jersey Lane Wayne NJ 07470 USA",
"source": "Groupon",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Self",
"suggestingUser": {
"userId": 1,
"firstName": "Gaurav",
"lastName": "Shandilya",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/1_1401692790212_Ashish"
}
},
{
"itemId": 1104,
"businessType": "SPORT",
"name": "Adirondack Sailing",
"websiteUrl": "http://www.yelp.com/biz/adirondack-sailing-new-york",
"rating": 4,
"city": "New York",
"address": "62 Chelsea Piers New York NY 10011",
"imageUrl": "http://s3-media1.ak.yelpcdn.com/bphoto/FwpUOlPWSpLlEteBGukcpg/ms.jpg",
"source": "Yelp",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Friend",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
}
},
{
"itemId": 1709,
"businessType": "SPORT",
"name": "Manhattan Sailing Club",
"websiteUrl": "http://www.yelp.com/biz/manhattan-sailing-club-new-york",
"rating": 4,
"city": "New York",
"address": "385 S End Ave Ste 6H Battery Park New York NY 10280",
"imageUrl": "http://s3-media1.ak.yelpcdn.com/bphoto/9yvzeSYaKfguvDUzF69xvw/ms.jpg",
"source": "Yelp",
"itemType": "Business",
"suggestionCriteria": "like",
"suggestedBy": "Friend",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
}
},
{
"eventId": 9743,
"description": "PARKING PASSES ONLY Igor Krutoi Gala Concert Tickets",
"event_date": "2015-01-31 00:00:00.0",
"venue_name": "Barclays Center Parking Lots",
"city": "Brooklyn",
"urlpath": "http://www.stubhub.com/parking-passes-only-igor-krutoi-gala-concert-brooklyn-barclays-center-parking-lots-31-1-2015-9004479",
"totalTickets": "0.0",
"title": "PARKING PASSES ONLY Igor Krutoi Gala Concert Tickets",
"ancestorGenreDescriptions": "[All tickets, Concert tickets, Artists H - K, Igor Krutoi Gala Tickets]",
"itemType": "Event",
"category": "Concert",
"source": "Stubhub",
"suggestionCriteria": "following",
"suggestedBy": "FriendSuggest",
"suggestingUser": {
"userId": 4,
"firstName": "Ashish",
"lastName": "Chandra",
"imageUrl": "http://54.243.29.6:8080/UploadedImages/4_1400934645640_Ashish"
},
"timeLine": "January 31 at 07:01 PM",
"startDate": "2015-01-31 00:00:00.0",
"endDate": "2015-01-31 00:00:00.0",
"address": "Barclays Center Parking Lots\nBrooklyn,New York 11217",
"isBooked": true
}
]
});
您可以在以下JSFiddle中看到这一点:http://jsfiddle.net/FvTjD/33/。当前解决方案表示评级大于或等于,因此,如果您选择评级为3,它将过滤那些评级为3及以上的项目。可以更改解决方案,以便轻松显示特定评级。