我目前正面临着我的Ionic应用程序的问题。我试图从(app.html)定义的侧边菜单中过滤页面上的离子卡。这是我的实习计划的学校项目,我真的很感激帮助。 该页面如下所示:That is my page with the array to be filtered和This is my side-menu filter
到目前为止,我对数组页面的代码如下所示,提前感谢:
import { Component } from '@angular/core';
import { IonicPage, NavController, NavParams, MenuController } from 'ionic-angular';
import { LocationsPage } from "../locations/locations";
import { AngularFireAuth } from "angularfire2/auth";
import { ToastController } from "ionic-angular";
import { RestPage } from "../rest/rest";
/**
* Generated class for the ContentPage page.
*
* See http://ionicframework.com/docs/components/#navigation for more info
* on Ionic pages and navigation.
*/
@IonicPage()
@Component({
selector: 'page-content',
templateUrl: 'content.html',
})
export class ContentPage {
modifiedData: any;
originalData: any;
constructor(private toast:ToastController,private afAuth: AngularFireAuth,public navCtrl: NavController, public navParams: NavParams, public menuCtrl: MenuController) {
this.navCtrl = navCtrl;
this.menuCtrl = menuCtrl;
// this.menuCtrl.enable(true, 'myMenu');
//array for the display of cards
//properties defined about the cards include:
//name-name of the Restaurant
//image-image to be used for the card
//text-text for the card
//PushPage-for pushing a specific page
//Price - defines price of a restaurant
// Cusisine - defines a restaurants Cuisine
//PAGE: SAME AS PUSHPAGE
this.originalData=[
{name:'Fairmont Hotel',image:'assets/images/fairmont.jpg',text:'Lorem Ipsum is simply dummy text of the printing and typesetting industry.', PushPage: 'RestPage',Price: 'low', Cuisine:'Kenyan',Page: RestPage},
{name:'MarymountHotel',image:'assets/images/fairmont.jpg',text:'Lorem Ipsum is simply dummy text of the printing and typesetting industry.', PushPage: 'RestPage',Price: 'Midrange',Cuisine:'Ethiopian', Page: RestPage}
];
this.modifiedData=JSON.parse(JSON.stringify(this.originalData));
}
//toast message to welcome a user to the app
ionViewWillLoad() {
this.afAuth.authState.subscribe(data =>{
if(data.email && data.uid){
this.toast.create({
message:'welcome to Rest',
duration: 3000
}).present();
}
})
}
//onclick event
itemSelected (PushPage) {
//alert(page);
var page = this.originalData.filter(function(it) {
return it.PushPage == PushPage
})[0].Page
//alert(page);
this.navCtrl.push(page);
}
//reset function
reset(){
this.modifiedData = JSON.parse(JSON.stringify(this.originalData));
}
//filtering function
filter(){
this.modifiedData=this.modifiedData.filter((rest)=>
{ return rest.Cuisine=='Kenyan'});
}
//toggel menu function
toggleLeftMenu() {
this.menuCtrl.toggle('left');
}
toggleRightMenu() {
this.menuCtrl.toggle('right');
}
//function that pushes from FAB button to LocationsPage
Locations(){
this.navCtrl.push(LocationsPage);
}
//function directing to the rest page that contains restaurant details
Rest(){
this.navCtrl.push(RestPage);
}
}
侧边菜单的代码如下:
<ion-menu side="left" [content]="content">
<ion-header id="background">
<ion-avatar item-start>
<img src="">
</ion-avatar>
</ion-header>
<ion-content>
<ion-list>
<button ion-item (click)="openPage(homePage)">
Reservations
</button>
<button ion-item (click)="openPage(friendsPage)">
Settings
</button>
</ion-list>
</ion-content>
</ion-menu>
<!-- second sidemenu -->
<ion-menu side="right" [content]="content">
<ion-header id="background2">
</ion-header>
<ion-content>
<ion-item>
<p>Im looking for:</p>
<ion-label stacked>Cuisine:</ion-label>
<ion-select [(ngModel)]="gender">
<ion-option value="K">Kenyan</ion-option>
<ion-option value="E">Ethiopian</ion-option>
<ion-option value="I">Indian</ion-option>
</ion-select>
</ion-item>
<ion-item>
<ion-label stacked>Vibe:</ion-label>
<ion-select [(ngModel)]="Vibe">
<ion-option value="C">Chilled</ion-option>
<ion-option value="F">Formal</ion-option>
</ion-select>
</ion-item>
<ion-item>
<ion-label stacked>price:</ion-label>
<ion-select [(ngModel)]="Price">
<ion-option value="L">Low</ion-option>
<ion-option value="M">Midrange</ion-option>
<ion-option value="H">HighPriced</ion-option>
</ion-select>
</ion-item>
<!-- grid for placing the buttons -->
<!-- first grid for the reset button -->
<ion-grid>
<ion-row>
<ion-col col-6>
<button ion-button color="secondary" outline (click)='reset()'>Reset</button>
</ion-col>
<!-- second column for the apply button -->
<ion-col col-6>
<button ion-button color="secondary" outline (click)='filter(rest)' >Apply </button>
</ion-col>
</ion-row>
</ion-grid>
</ion-content>
</ion-menu>
<!-- Disable swipe-to-go-back because it's poor UX to combine STGB with side menus -->
<ion-nav [root]="rootPage" #content ></ion-nav>
答案 0 :(得分:2)
为filter
f.e创建一个包装器对象。 {price: string, vibe: string}
您可以跟踪所选过滤器。
<强> SRC /模型/ filter.model.ts 强>
export class FilterWrapper {
price: string = "NONE"; //default value
vibe: string = "NONE";
cuisine: string = "NONE";
}
<强>的src /应用程序/ app.component.ts 强>
现在,当过滤器更改时(在app.component.ts中),使您的功能如下:
import { Events } from 'ionic-angular';
import { FilterWrapper } from '../models/filter.model';
@Component({...})
export class AppComponent{
filterWrapper: FilterWrapper;
constructor(events: Events) {
// creates a filterwrapper {price: "NONE", vibe:"NONE",cuisine:"NONE"}
this.filterWrapper = new FilterWrapper();
}
saveFilters() {
this.events.publish('filters:changed', this.filterWrapper);
// where this.filterWrapper contains the selected filters (ngModel on select list f.e.)
}
}
<强>的src /应用程序/ app.component.html 强>
<!-- only 1 example provided -->
<ion-select [(ngModel)]="filterWrapper.cuisine">
<ion-option value="K">Kenyan</ion-option>
<ion-option value="E">Ethiopian</ion-option>
<ion-option value="I">Indian</ion-option>
</ion-select>
</ion-item>
现在在数组页面中监听此更改事件:
<强>的src /页/ content.component.ts 强>
import { Events } from 'ionic-angular';
import { FilterWrapper } from '../models/filter.model';
export class ContentPage {
filterWrapper: FilterWrapper = new FilterWrapper();
allItems = []; // your 'all' item list to display, normally filled.
constructor(events: Events) {
events.subscribe('filters:changed', filter => {
this.filterWrapper = filter;
}
}
// returns true if the item matches the selected filters
// yes could be more efficient but this is more comprehensive.
matchesFilters(item: any) {
let filter = this.filterWrapper;
let result: boolean = false;
// default true in case cuisine is "NONE"
let cuisineResult = true;
if(filter.cuisine != "NONE") {
cuisineResult = filter.cuisine == item.cuisine;
}
let vibeResult = true;
if(filter.vice != "NONE") {
vibeResult = filter.vibe == item.vibe;
}
let priceResult = true;
if(filter.price != "NONE") {
priceResult = filters.price == item.price;
}
// true if all are or false if one of them is false
result = (cuisineResult && vibeResult && priceResult);
return result;
}
}
在您的 src / pages / content.component.html 页面中,您将获得以下内容:
<ion-item *ngFor="let item of allItems">
现在因为你不能在1个项目上有2个*
,这有点令人讨厌的解决办法是:
<!-- loop through the list and create an item for all of them -->
<div *ngFor="let item of allItems">
<!-- dont show the item if it doesn't match the filters -->
<ion-item *ngIf="!matchesFilters(item)>
<!-- dont put your *ngIf on the <ion-card> else the <ion-item> will still be created and that takes up space in your page -->
<ion-card>
....