フィルタとは
リストに表示されるレコードを、特定の条件で絞りたい場合にフィルタを使います。SAPUI5では、SearchFieldというコントロールを使ってフィルタを実装します。
フィルタの実装
ゴール
リストに検索条件を追加して、製品名で結果を絞り込めるようにします。
ステップ
- ビューにSearchFiledを追加
- コントローラに検索メソッドを追加
1. ビューにSearchFiledを追加
App.view.xmlのList以下を次のように変更します。
変更前
<List items="{mPricelist>/products}">
<items>
<ObjectListItem
・・・
変更後
<List
id="productList"
items="{mPricelist>/products}">
<headerToolbar>
<Toolbar>
<Title width="100%" text="Products"/>
<SearchField search="onFilterProducts"/>
</Toolbar>
</headerToolbar>
コントローラ側でリストを特定できるようにidを付与します。
Listの先頭にToolbarを置き、その中にTitleとSearchFieldを配置します。
SearchFildには、検索を実行したときに呼ばれるメソッドを指定します。
ところで、Toolbarの中にはどんなコントロールを置けるのでしょうか?
sap.m.Toolbarのリファレンスを見たところ、Aggregationsの型がsap.ui.core.Controlとなっているので、何でもOKのようです。(試しにButtonを追加してみたところ、できました)
2. コントローラに検索メソッドを追加
App.controller.jsに以下のコードを追加します。
sap.ui.define([
"sap/ui/core/mvc/Controller",
"sap/ui/model/json/JSONModel",
"sap/m/MessageToast",
//追加↓
"sap/ui/model/Filter",
"sap/ui/model/FilterOperator",
//追加↑
"test/helloworld/model/formatter"
], function (Controller, JSONModel, MessageToast, 追加→Filter, 追加→FilterOperator, formatter) {
"use strict";
return Controller.extend("test.helloworld.controller.App", {
formatter: formatter,
_data : {
"date" : new Date()
},
onInit : function (oEvent) {
var oModel = new JSONModel(this._data);
this.getView().setModel(oModel);
},
onShowHello : function () {
// read msg from i18n model
var oBundle = this.getView().getModel("i18n").getResourceBundle();
var sProduct = this.getView().getModel("mPrice").getProperty("/product/name");
var sMsg = oBundle.getText("helloMessage", [sProduct]);
// show a native JavaScript alert
MessageToast.show(sMsg);
},
//追加
onFilterProducts : function (oEvent) {
// build filter array
var aFilter = [];
var sQuery = oEvent.getParameter("query");
if (sQuery) {
aFilter.push(new Filter("name", FilterOperator.Contains, sQuery));
}
// filter binding
var oList = this.byId("productList");
var oBinding = oList.getBinding("items");
oBinding.filter(aFilter);
},
});
});
まず、FilterとFilterOperatorという2つのクラスを使うために先頭にこれらを追加します。
onFilterProductsメソッドの中では、SearchFieldに入力した検索条件を取得します。
条件が入力されている場合はフィルタオブジェクトを作成して配列に格納します。
※条件が未入力の場合、配列は空のままです。これによって条件を指定せずに検索実行したときにフィルタがかからないようになります。
続いてリストにバインドされたitemを取得し、itemに対してfilterを実行します。
参考までに、デバッグで見てみるとイベントパラメータのqueryというパラメータに入力した条件が設定されているのが確認できました。
結果
以下のように、製品名(name)で絞り込みがされます。検索条件の大文字小文字は区別されません。
Filterの生成方法についてもう少し詳しく
Filterオブジェクトは以下のように生成しました。
new Filter("name", FilterOperator.Contains, sQuery)
第一引数はpath(どの項目に対してフィルタをかけるか), 第二引数はoperator(フィルタ条件)、第三引数はvalue(フィルタ値)です。
Filterは以下の3つの生成方法があります。今回のケースは1番目に当たります。
- path, operator, 1つまたは2つのvalue(value1, value2)
- path, 独自のフィルタ用ファンクション(test)
- filtersでくくった複数のフィルタと、それらのフィルタをANDでつなげるかORでつなげるかのフラグ(ture=AND, false=OR)
詳しくは下記を参照してください。
sap.ui.model.Filter
FilterOperatorとは?
FilterOperatorはフィルタ条件を指定するための定数の集まりです。
フィルタ条件とは、指定した値を「含む」なのか「等しい」なのかといった条件のことです。
今回はContainsを使いましたが、これは「含む」に該当します。
その他、一部を以下に記載します。これ以外の値については下記をご参照ください。
sap.ui.model.FilterOperator
値 | 意味 |
---|---|
sap.ui.model.FilterOperator.BT | 2つの値の間 |
sap.ui.model.FilterOperator.EndsWith | ~で終わる |
sap.ui.model.FilterOperator.EQ | ~に等しい |
sap.ui.model.FilterOperator.GT | ~より大きい |
sap.ui.model.FilterOperator.StartsWith | ~で始まる |
参考にしたページ
Get Started: Setup and Tutorials-Walkthrough-Step 24: Filtering