コンボボックス:ソートとフィルター

CollectionViewを使用して、ComboBoxに連結されたデータをフィルターおよびソートすることができます。現在選択されている項目にアクセスするには、ComboBox.selectedItemの代わりにCollectionView.currentItemを使用できます。このサンプルは、元のデータソース内のアイテムを「人口 > 2000万」でフィルターし、項目を国名で並べ替えます。

import 'bootstrap.css'; import '@grapecity/wijmo.styles/wijmo.css'; import './styles.css'; // import * as wijmo from '@grapecity/wijmo'; import * as input from '@grapecity/wijmo.input'; import { getData } from './data'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { // define a template for showing the current item's details let detailTemplate = '<div>' + '<div>国: <b>{country}</b></div>' + '<div>GDP(100万ドル/年): <b>{gdpm:c0$}</b></div>' + '<div>人口(千): <b>{popk:n0}</b></div>' + '<div>1人当たりのGDP(ドル): <b>{gdpcap:c0$}</b></div>' + '<div>ランク: <b>{id}</b></div>' + '</div>'; // let view = new wijmo.CollectionView(getData(), { // update detail when current item changes currentChanged: (sender) => { let html = wijmo.format(detailTemplate, sender.currentItem, (data, name, fmt, val) => { if (wijmo.isString(data[name])) { val = wijmo.escapeHtml(data[name]); } return val; }); // document.getElementById('detail').innerHTML = html; }, // // 20 million people or more filter: (item) => item.popk > 20000, // // sort and filter the collectionView sortDescriptions: [ new wijmo.SortDescription('country', true) ] }); // // combo and CollectionView let theCombo = new input.ComboBox('#theCombo', { displayMemberPath: 'country', itemsSource: view }); } <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>GrapeCity ComboBox Sorting and Filtering Items</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="node_modules/systemjs/dist/system.src.js"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div class="container-fluid"> <div class="form-group"> <label for="theCombo">項目を選択:</label> <div id="theCombo"></div> </div> <p id="detail"></p> </div> </body> </html> // export function getData() { return [ { id: 1, country: 'ルクセンブルク', gdpm: 57825, popk: 563, gdpcap: 102708 }, { id: 2, country: 'スイス', gdpm: 664005, popk: 8238, gdpcap: 80602 }, { id: 3, country: 'ノルウェー', gdpm: 388315, popk: 5205, gdpcap: 74604 }, { id: 4, country: 'マカオ', gdpm: 46178, popk: 647, gdpcap: 71372 }, { id: 5, country: 'カタール', gdpm: 166908, popk: 2421, gdpcap: 68941 }, { id: 6, country: 'アイルランド', gdpm: 283716, popk: 4635, gdpcap: 61211 }, { id: 7, country: 'アメリカ', gdpm: 18036650, popk: 321601, gdpcap: 56083 }, { id: 8, country: 'シンガポール', gdpm: 292734, popk: 5535, gdpcap: 52887 }, { id: 9, country: 'デンマーク', gdpm: 295091, popk: 5660, gdpcap: 52136 }, { id: 10, country: 'オーストラリア', gdpm: 1225286, popk: 23940, gdpcap: 51181 }, { id: 11, country: 'アイスランド', gdpm: 16718, popk: 333, gdpcap: 50204 }, { id: 12, country: 'スウェーデン', gdpm: 493042, popk: 9851, gdpcap: 50049 }, { id: 13, country: 'サンマリノ', gdpm: 1558, popk: 31, gdpcap: 50258 }, { id: 14, country: 'オランダ', gdpm: 750696, popk: 16937, gdpcap: 44322 }, { id: 15, country: 'イギリス', gdpm: 2858482, popk: 65110, gdpcap: 43902 }, { id: 16, country: 'オーストリア', gdpm: 374261, popk: 8621, gdpcap: 43412 }, { id: 17, country: 'カナダ', gdpm: 1550537, popk: 35825, gdpcap: 43280 }, { id: 18, country: 'フィンランド', gdpm: 232077, popk: 5472, gdpcap: 42411 }, { id: 19, country: 'ドイツ', gdpm: 3365293, popk: 82176, gdpcap: 40952 }, { id: 20, country: 'ベルギー', gdpm: 454288, popk: 11209, gdpcap: 40528 }, { id: 21, country: 'アラブ首長国連邦', gdpm: 370296, popk: 9581, gdpcap: 38648 }, { id: 22, country: 'フランス', gdpm: 2420163, popk: 64275, gdpcap: 37653 }, { id: 23, country: 'ニュージーランド', gdpm: 172257, popk: 4647, gdpcap: 37068 }, { id: 24, country: 'イスラエル', gdpm: 299413, popk: 8377, gdpcap: 35742 }, { id: 25, country: '日本', gdpm: 4124211, popk: 126981, gdpcap: 32478 }, { id: 26, country: 'ブルネイ', gdpm: 12930, popk: 417, gdpcap: 31007 }, { id: 27, country: 'イタリア', gdpm: 1815759, popk: 60796, gdpcap: 29866 }, { id: 28, country: 'プエルトリコ', gdpm: 102906, popk: 3474, gdpcap: 29621 }, { id: 29, country: 'クウェート', gdpm: 114079, popk: 4110, gdpcap: 27756 }, { id: 30, country: '韓国', gdpm: 1377873, popk: 50617, gdpcap: 27221 }, { id: 31, country: 'スペイン', gdpm: 1199715, popk: 46423, gdpcap: 25843 }, { id: 32, country: 'バハマ', gdpm: 8854, popk: 364, gdpcap: 24324 }, { id: 33, country: 'バーレーン', gdpm: 31119, popk: 1294, gdpcap: 24048 }, { id: 34, country: 'キプロス', gdpm: 19330, popk: 847, gdpcap: 22821 }, { id: 35, country: 'マルタ', gdpm: 9752, popk: 429, gdpcap: 22731 }, { id: 36, country: '台湾', gdpm: 523006, popk: 23492, gdpcap: 22263 }, { id: 37, country: 'スロベニア', gdpm: 42798, popk: 2063, gdpcap: 20745 }, { id: 38, country: 'サウジアラビア', gdpm: 646002, popk: 31386, gdpcap: 20582 }, { id: 39, country: 'ポルトガル', gdpm: 199032, popk: 10411, gdpcap: 19117 }, { id: 40, country: 'トリニダード・トバゴ', gdpm: 24631, popk: 1358, gdpcap: 18137 }, { id: 41, country: 'ギリシャ', gdpm: 195320, popk: 10858, gdpcap: 17988 }, { id: 42, country: 'チェコ共和国', gdpm: 185156, popk: 10538, gdpcap: 17570 }, { id: 43, country: 'エストニア', gdpm: 22704, popk: 1313, gdpcap: 17291 }, { id: 44, country: '赤道ギニア', gdpm: 13819, popk: 799, gdpcap: 17295 }, { id: 45, country: 'オマーン', gdpm: 64121, popk: 3840, gdpcap: 16698 }, { id: 46, country: 'セントキッツ・ネイビス', gdpm: 915, popk: 56, gdpcap: 16339 }, { id: 47, country: 'パラオ', gdpm: 287, popk: 18, gdpcap: 15944 }, { id: 48, country: 'スロバキア', gdpm: 86629, popk: 5421, gdpcap: 15980 }, { id: 49, country: 'バルバドス', gdpm: 4385, popk: 280, gdpcap: 15660 }, { id: 50, country: 'ウルグアイ', gdpm: 53107, popk: 3416, gdpcap: 15546 } ]; } body { margin-bottom: 24px; } label { margin-right: 3px; } import 'bootstrap.css'; import '@grapecity/wijmo.styles/wijmo.css'; import './styles.css'; // import * as wijmo from '@grapecity/wijmo'; // import { Component, enableProdMode, NgModule, Inject } from '@angular/core'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { BrowserModule } from '@angular/platform-browser'; import { WjInputModule } from '@grapecity/wijmo.angular2.input'; import { DataService, TDataItem } from './app.data'; // @Component({ selector: 'app-component', templateUrl: 'src/app.component.html' }) export class AppComponent { data: wijmo.CollectionView; // constructor(@Inject(DataService) private dataService: DataService) { this.data = new wijmo.CollectionView(dataService.getData(), { // 20 million people or more filter: (item: TDataItem) => item.popk > 20000, // sort and filter the collectionView sortDescriptions: [ new wijmo.SortDescription('country', true) ] }); } } // @NgModule({ imports: [WjInputModule, BrowserModule], declarations: [AppComponent], providers: [DataService], bootstrap: [AppComponent] }) export class AppModule { } // enableProdMode(); // Bootstrap application with hash style navigation and global services. platformBrowserDynamic().bootstrapModule(AppModule); <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>GrapeCity ComboBox Sorting and Filtering Items</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- Polyfills --> <script src="node_modules/core-js/client/shim.min.js"></script> <script src="node_modules/zone.js/dist/zone.min.js"></script> <!-- SystemJS --> <script src="node_modules/systemjs/dist/system.js"></script> <script src="systemjs.config.js"></script> <script> // workaround to load 'rxjs/operators' from the rxjs bundle System.import('rxjs').then(function (m) { System.set(SystemJS.resolveSync('rxjs/operators'), System.newModule(m.operators)); System.import('./src/app.component'); }); </script> </head> <body> <app-component></app-component> </body> </html> <div class="container-fluid"> <div class="form-group"> <label for="theCombo">項目を選択:</label> <wj-combo-box #theCombo id="theCombo" [displayMemberPath]="'country'" [itemsSource]="data"></wj-combo-box> </div> <div *ngIf="theCombo.collectionView?.currentItem as c"> <div>国: <b>{{ c.country }}</b></div> <div>GDP(100万ドル/年): <b>{{ c.gdpm | currency:undefined:undefined:'2.0-0' }}</b></div> <div>人口(千): <b>{{ c.popk | number:'1.0-0' }}</b></div> <div>1人当たりのGDP(ドル): <b>{{ c.gdpcap | currency:undefined:undefined:'2.0-0' }}</b></div> <div>ランク: <b>{{ c.id }}</b></div> </div> </div> import { Injectable } from '@angular/core'; // export type TDataItem = { id: number; country: string; gdpm: number; popk: number; gdpcap: number; } // @Injectable() export class DataService { getData() { return <TDataItem[]>[ { id: 1, country: 'ルクセンブルク', gdpm: 57825, popk: 563, gdpcap: 102708 }, { id: 2, country: 'スイス', gdpm: 664005, popk: 8238, gdpcap: 80602 }, { id: 3, country: 'ノルウェー', gdpm: 388315, popk: 5205, gdpcap: 74604 }, { id: 4, country: 'マカオ', gdpm: 46178, popk: 647, gdpcap: 71372 }, { id: 5, country: 'カタール', gdpm: 166908, popk: 2421, gdpcap: 68941 }, { id: 6, country: 'アイルランド', gdpm: 283716, popk: 4635, gdpcap: 61211 }, { id: 7, country: 'アメリカ', gdpm: 18036650, popk: 321601, gdpcap: 56083 }, { id: 8, country: 'シンガポール', gdpm: 292734, popk: 5535, gdpcap: 52887 }, { id: 9, country: 'デンマーク', gdpm: 295091, popk: 5660, gdpcap: 52136 }, { id: 10, country: 'オーストラリア', gdpm: 1225286, popk: 23940, gdpcap: 51181 }, { id: 11, country: 'アイスランド', gdpm: 16718, popk: 333, gdpcap: 50204 }, { id: 12, country: 'スウェーデン', gdpm: 493042, popk: 9851, gdpcap: 50049 }, { id: 13, country: 'サンマリノ', gdpm: 1558, popk: 31, gdpcap: 50258 }, { id: 14, country: 'オランダ', gdpm: 750696, popk: 16937, gdpcap: 44322 }, { id: 15, country: 'イギリス', gdpm: 2858482, popk: 65110, gdpcap: 43902 }, { id: 16, country: 'オーストリア', gdpm: 374261, popk: 8621, gdpcap: 43412 }, { id: 17, country: 'カナダ', gdpm: 1550537, popk: 35825, gdpcap: 43280 }, { id: 18, country: 'フィンランド', gdpm: 232077, popk: 5472, gdpcap: 42411 }, { id: 19, country: 'ドイツ', gdpm: 3365293, popk: 82176, gdpcap: 40952 }, { id: 20, country: 'ベルギー', gdpm: 454288, popk: 11209, gdpcap: 40528 }, { id: 21, country: 'アラブ首長国連邦', gdpm: 370296, popk: 9581, gdpcap: 38648 }, { id: 22, country: 'フランス', gdpm: 2420163, popk: 64275, gdpcap: 37653 }, { id: 23, country: 'ニュージーランド', gdpm: 172257, popk: 4647, gdpcap: 37068 }, { id: 24, country: 'イスラエル', gdpm: 299413, popk: 8377, gdpcap: 35742 }, { id: 25, country: '日本', gdpm: 4124211, popk: 126981, gdpcap: 32478 }, { id: 26, country: 'ブルネイ', gdpm: 12930, popk: 417, gdpcap: 31007 }, { id: 27, country: 'イタリア', gdpm: 1815759, popk: 60796, gdpcap: 29866 }, { id: 28, country: 'プエルトリコ', gdpm: 102906, popk: 3474, gdpcap: 29621 }, { id: 29, country: 'クウェート', gdpm: 114079, popk: 4110, gdpcap: 27756 }, { id: 30, country: '韓国', gdpm: 1377873, popk: 50617, gdpcap: 27221 }, { id: 31, country: 'スペイン', gdpm: 1199715, popk: 46423, gdpcap: 25843 }, { id: 32, country: 'バハマ', gdpm: 8854, popk: 364, gdpcap: 24324 }, { id: 33, country: 'バーレーン', gdpm: 31119, popk: 1294, gdpcap: 24048 }, { id: 34, country: 'キプロス', gdpm: 19330, popk: 847, gdpcap: 22821 }, { id: 35, country: 'マルタ', gdpm: 9752, popk: 429, gdpcap: 22731 }, { id: 36, country: '台湾', gdpm: 523006, popk: 23492, gdpcap: 22263 }, { id: 37, country: 'スロベニア', gdpm: 42798, popk: 2063, gdpcap: 20745 }, { id: 38, country: 'サウジアラビア', gdpm: 646002, popk: 31386, gdpcap: 20582 }, { id: 39, country: 'ポルトガル', gdpm: 199032, popk: 10411, gdpcap: 19117 }, { id: 40, country: 'トリニダード・トバゴ', gdpm: 24631, popk: 1358, gdpcap: 18137 }, { id: 41, country: 'ギリシャ', gdpm: 195320, popk: 10858, gdpcap: 17988 }, { id: 42, country: 'チェコ共和国', gdpm: 185156, popk: 10538, gdpcap: 17570 }, { id: 43, country: 'エストニア', gdpm: 22704, popk: 1313, gdpcap: 17291 }, { id: 44, country: '赤道ギニア', gdpm: 13819, popk: 799, gdpcap: 17295 }, { id: 45, country: 'オマーン', gdpm: 64121, popk: 3840, gdpcap: 16698 }, { id: 46, country: 'セントキッツ・ネイビス', gdpm: 915, popk: 56, gdpcap: 16339 }, { id: 47, country: 'パラオ', gdpm: 287, popk: 18, gdpcap: 15944 }, { id: 48, country: 'スロバキア', gdpm: 86629, popk: 5421, gdpcap: 15980 }, { id: 49, country: 'バルバドス', gdpm: 4385, popk: 280, gdpcap: 15660 }, { id: 50, country: 'ウルグアイ', gdpm: 53107, popk: 3416, gdpcap: 15546 } ]; } } body { margin-bottom: 24px; } label { margin-right: 3px; } import 'bootstrap.css'; import '@grapecity/wijmo.styles/wijmo.css'; import './app.css'; // import * as React from 'react'; import * as ReactDOM from 'react-dom'; // import * as wijmo from '@grapecity/wijmo'; import * as wjInput from '@grapecity/wijmo.react.input'; import { getData } from './data'; // class App extends React.Component { constructor() { super(...arguments); this._data = new wijmo.CollectionView(getData(), { currentChanged: () => this.forceUpdate(), // 20 million people or more filter: (item) => item.popk > 20000, // sort and filter the collectionView sortDescriptions: [ new wijmo.SortDescription('country', true) ] }); } render() { return <div className="container-fluid"> <div className="form-group"> <label htmlFor="theCombo">項目を選択:</label> <wjInput.ComboBox id="theCombo" displayMemberPath="country" itemsSource={this._data}> </wjInput.ComboBox> </div> {this._data.currentItem ? (<div> <div>国: <b>{this._data.currentItem.country}</b></div> <div>GDP(100万ドル/年): <b>{this.formatCurrency(this._data.currentItem.gdpm)}</b></div> <div>人口(千): <b>{this.formatNumber(this._data.currentItem.popk)}</b></div> <div>1人当たりのGDP(ドル): <b>{this.formatCurrency(this._data.currentItem.gdpcap)}</b></div> <div>ランク: <b>{this._data.currentItem.id}</b></div> </div>) : null} </div>; } formatCurrency(number) { return wijmo.Globalize.format(number, 'c0$'); } formatNumber(number) { return wijmo.Globalize.format(number, 'n'); } } ReactDOM.render(<App />, document.getElementById('app')); <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>GrapeCity ComboBox Sorting and Filtering Items</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="node_modules/systemjs/dist/system.src.js"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div id="app"></div> </body> </html> body { margin-bottom: 24px; } label { margin-right: 3px; } export function getData() { return [ { id: 1, country: 'ルクセンブルク', gdpm: 57825, popk: 563, gdpcap: 102708 }, { id: 2, country: 'スイス', gdpm: 664005, popk: 8238, gdpcap: 80602 }, { id: 3, country: 'ノルウェー', gdpm: 388315, popk: 5205, gdpcap: 74604 }, { id: 4, country: 'マカオ', gdpm: 46178, popk: 647, gdpcap: 71372 }, { id: 5, country: 'カタール', gdpm: 166908, popk: 2421, gdpcap: 68941 }, { id: 6, country: 'アイルランド', gdpm: 283716, popk: 4635, gdpcap: 61211 }, { id: 7, country: 'アメリカ', gdpm: 18036650, popk: 321601, gdpcap: 56083 }, { id: 8, country: 'シンガポール', gdpm: 292734, popk: 5535, gdpcap: 52887 }, { id: 9, country: 'デンマーク', gdpm: 295091, popk: 5660, gdpcap: 52136 }, { id: 10, country: 'オーストラリア', gdpm: 1225286, popk: 23940, gdpcap: 51181 }, { id: 11, country: 'アイスランド', gdpm: 16718, popk: 333, gdpcap: 50204 }, { id: 12, country: 'スウェーデン', gdpm: 493042, popk: 9851, gdpcap: 50049 }, { id: 13, country: 'サンマリノ', gdpm: 1558, popk: 31, gdpcap: 50258 }, { id: 14, country: 'オランダ', gdpm: 750696, popk: 16937, gdpcap: 44322 }, { id: 15, country: 'イギリス', gdpm: 2858482, popk: 65110, gdpcap: 43902 }, { id: 16, country: 'オーストリア', gdpm: 374261, popk: 8621, gdpcap: 43412 }, { id: 17, country: 'カナダ', gdpm: 1550537, popk: 35825, gdpcap: 43280 }, { id: 18, country: 'フィンランド', gdpm: 232077, popk: 5472, gdpcap: 42411 }, { id: 19, country: 'ドイツ', gdpm: 3365293, popk: 82176, gdpcap: 40952 }, { id: 20, country: 'ベルギー', gdpm: 454288, popk: 11209, gdpcap: 40528 }, { id: 21, country: 'アラブ首長国連邦', gdpm: 370296, popk: 9581, gdpcap: 38648 }, { id: 22, country: 'フランス', gdpm: 2420163, popk: 64275, gdpcap: 37653 }, { id: 23, country: 'ニュージーランド', gdpm: 172257, popk: 4647, gdpcap: 37068 }, { id: 24, country: 'イスラエル', gdpm: 299413, popk: 8377, gdpcap: 35742 }, { id: 25, country: '日本', gdpm: 4124211, popk: 126981, gdpcap: 32478 }, { id: 26, country: 'ブルネイ', gdpm: 12930, popk: 417, gdpcap: 31007 }, { id: 27, country: 'イタリア', gdpm: 1815759, popk: 60796, gdpcap: 29866 }, { id: 28, country: 'プエルトリコ', gdpm: 102906, popk: 3474, gdpcap: 29621 }, { id: 29, country: 'クウェート', gdpm: 114079, popk: 4110, gdpcap: 27756 }, { id: 30, country: '韓国', gdpm: 1377873, popk: 50617, gdpcap: 27221 }, { id: 31, country: 'スペイン', gdpm: 1199715, popk: 46423, gdpcap: 25843 }, { id: 32, country: 'バハマ', gdpm: 8854, popk: 364, gdpcap: 24324 }, { id: 33, country: 'バーレーン', gdpm: 31119, popk: 1294, gdpcap: 24048 }, { id: 34, country: 'キプロス', gdpm: 19330, popk: 847, gdpcap: 22821 }, { id: 35, country: 'マルタ', gdpm: 9752, popk: 429, gdpcap: 22731 }, { id: 36, country: '台湾', gdpm: 523006, popk: 23492, gdpcap: 22263 }, { id: 37, country: 'スロベニア', gdpm: 42798, popk: 2063, gdpcap: 20745 }, { id: 38, country: 'サウジアラビア', gdpm: 646002, popk: 31386, gdpcap: 20582 }, { id: 39, country: 'ポルトガル', gdpm: 199032, popk: 10411, gdpcap: 19117 }, { id: 40, country: 'トリニダード・トバゴ', gdpm: 24631, popk: 1358, gdpcap: 18137 }, { id: 41, country: 'ギリシャ', gdpm: 195320, popk: 10858, gdpcap: 17988 }, { id: 42, country: 'チェコ共和国', gdpm: 185156, popk: 10538, gdpcap: 17570 }, { id: 43, country: 'エストニア', gdpm: 22704, popk: 1313, gdpcap: 17291 }, { id: 44, country: '赤道ギニア', gdpm: 13819, popk: 799, gdpcap: 17295 }, { id: 45, country: 'オマーン', gdpm: 64121, popk: 3840, gdpcap: 16698 }, { id: 46, country: 'セントキッツ・ネイビス', gdpm: 915, popk: 56, gdpcap: 16339 }, { id: 47, country: 'パラオ', gdpm: 287, popk: 18, gdpcap: 15944 }, { id: 48, country: 'スロバキア', gdpm: 86629, popk: 5421, gdpcap: 15980 }, { id: 49, country: 'バルバドス', gdpm: 4385, popk: 280, gdpcap: 15660 }, { id: 50, country: 'ウルグアイ', gdpm: 53107, popk: 3416, gdpcap: 15546 } ]; } <template> <div class="container-fluid"> <div class="form-group"> <label for="theCombo">項目を選択:</label> <wj-combo-box id="theCombo" :displayMemberPath="'country'" :itemsSource="data" :initialized="initCombo"></wj-combo-box> </div> <div v-if="theCombo.collectionView.currentItem"> <div>国: <b>{{ theCombo.collectionView.currentItem.country }}</b></div> <div>GDP(100万ドル/年): <b>{{ theCombo.collectionView.currentItem.gdpm | formatCurrency }}</b></div> <div>人口(千): <b>{{ theCombo.collectionView.currentItem.popk | formatNumber }}</b></div> <div>1人当たりのGDP(ドル): <b>{{ theCombo.collectionView.currentItem.gdpcap | formatCurrency }}</b></div> <div>ランク: <b>{{ theCombo.collectionView.currentItem.id }}</b></div> </div> </div> </template> <script> import 'bootstrap.css'; import '@grapecity/wijmo.styles/wijmo.css'; import Vue from 'vue'; import '@grapecity/wijmo.vue2.core'; import '@grapecity/wijmo.vue2.input'; import { getData } from './data'; let App = Vue.extend({ name: 'app', data: function () { return { theCombo: { collectionView: { currentItem: null } }, data: new wijmo.CollectionView(getData(), { // 20 million people or more filter: (item) => item.popk > 20000, // sort and filter the collectionView sortDescriptions: [ new wijmo.SortDescription('country', true) ] }) } }, methods: { initCombo: function(combo) { this.theCombo = combo; } }, filters: { formatCurrency: function(number){ return wijmo.Globalize.format(number, 'c0$'); }, formatNumber: function(number){ return wijmo.Globalize.format(number, 'n'); } } }) let vm = new Vue({ render: h => h(App) }).$mount('#app'); </script> <style> body { margin-bottom: 24px; } label { margin-right: 3px; } </style> <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>GrapeCity ComboBox Sorting and Filtering Items</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="node_modules/systemjs/dist/system.src.js"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app.vue'); </script> </head> <body> <div id="app"></div> </body> </html> // export function getData() { return [ { id: 1, country: 'ルクセンブルク', gdpm: 57825, popk: 563, gdpcap: 102708 }, { id: 2, country: 'スイス', gdpm: 664005, popk: 8238, gdpcap: 80602 }, { id: 3, country: 'ノルウェー', gdpm: 388315, popk: 5205, gdpcap: 74604 }, { id: 4, country: 'マカオ', gdpm: 46178, popk: 647, gdpcap: 71372 }, { id: 5, country: 'カタール', gdpm: 166908, popk: 2421, gdpcap: 68941 }, { id: 6, country: 'アイルランド', gdpm: 283716, popk: 4635, gdpcap: 61211 }, { id: 7, country: 'アメリカ', gdpm: 18036650, popk: 321601, gdpcap: 56083 }, { id: 8, country: 'シンガポール', gdpm: 292734, popk: 5535, gdpcap: 52887 }, { id: 9, country: 'デンマーク', gdpm: 295091, popk: 5660, gdpcap: 52136 }, { id: 10, country: 'オーストラリア', gdpm: 1225286, popk: 23940, gdpcap: 51181 }, { id: 11, country: 'アイスランド', gdpm: 16718, popk: 333, gdpcap: 50204 }, { id: 12, country: 'スウェーデン', gdpm: 493042, popk: 9851, gdpcap: 50049 }, { id: 13, country: 'サンマリノ', gdpm: 1558, popk: 31, gdpcap: 50258 }, { id: 14, country: 'オランダ', gdpm: 750696, popk: 16937, gdpcap: 44322 }, { id: 15, country: 'イギリス', gdpm: 2858482, popk: 65110, gdpcap: 43902 }, { id: 16, country: 'オーストリア', gdpm: 374261, popk: 8621, gdpcap: 43412 }, { id: 17, country: 'カナダ', gdpm: 1550537, popk: 35825, gdpcap: 43280 }, { id: 18, country: 'フィンランド', gdpm: 232077, popk: 5472, gdpcap: 42411 }, { id: 19, country: 'ドイツ', gdpm: 3365293, popk: 82176, gdpcap: 40952 }, { id: 20, country: 'ベルギー', gdpm: 454288, popk: 11209, gdpcap: 40528 }, { id: 21, country: 'アラブ首長国連邦', gdpm: 370296, popk: 9581, gdpcap: 38648 }, { id: 22, country: 'フランス', gdpm: 2420163, popk: 64275, gdpcap: 37653 }, { id: 23, country: 'ニュージーランド', gdpm: 172257, popk: 4647, gdpcap: 37068 }, { id: 24, country: 'イスラエル', gdpm: 299413, popk: 8377, gdpcap: 35742 }, { id: 25, country: '日本', gdpm: 4124211, popk: 126981, gdpcap: 32478 }, { id: 26, country: 'ブルネイ', gdpm: 12930, popk: 417, gdpcap: 31007 }, { id: 27, country: 'イタリア', gdpm: 1815759, popk: 60796, gdpcap: 29866 }, { id: 28, country: 'プエルトリコ', gdpm: 102906, popk: 3474, gdpcap: 29621 }, { id: 29, country: 'クウェート', gdpm: 114079, popk: 4110, gdpcap: 27756 }, { id: 30, country: '韓国', gdpm: 1377873, popk: 50617, gdpcap: 27221 }, { id: 31, country: 'スペイン', gdpm: 1199715, popk: 46423, gdpcap: 25843 }, { id: 32, country: 'バハマ', gdpm: 8854, popk: 364, gdpcap: 24324 }, { id: 33, country: 'バーレーン', gdpm: 31119, popk: 1294, gdpcap: 24048 }, { id: 34, country: 'キプロス', gdpm: 19330, popk: 847, gdpcap: 22821 }, { id: 35, country: 'マルタ', gdpm: 9752, popk: 429, gdpcap: 22731 }, { id: 36, country: '台湾', gdpm: 523006, popk: 23492, gdpcap: 22263 }, { id: 37, country: 'スロベニア', gdpm: 42798, popk: 2063, gdpcap: 20745 }, { id: 38, country: 'サウジアラビア', gdpm: 646002, popk: 31386, gdpcap: 20582 }, { id: 39, country: 'ポルトガル', gdpm: 199032, popk: 10411, gdpcap: 19117 }, { id: 40, country: 'トリニダード・トバゴ', gdpm: 24631, popk: 1358, gdpcap: 18137 }, { id: 41, country: 'ギリシャ', gdpm: 195320, popk: 10858, gdpcap: 17988 }, { id: 42, country: 'チェコ共和国', gdpm: 185156, popk: 10538, gdpcap: 17570 }, { id: 43, country: 'エストニア', gdpm: 22704, popk: 1313, gdpcap: 17291 }, { id: 44, country: '赤道ギニア', gdpm: 13819, popk: 799, gdpcap: 17295 }, { id: 45, country: 'オマーン', gdpm: 64121, popk: 3840, gdpcap: 16698 }, { id: 46, country: 'セントキッツ・ネイビス', gdpm: 915, popk: 56, gdpcap: 16339 }, { id: 47, country: 'パラオ', gdpm: 287, popk: 18, gdpcap: 15944 }, { id: 48, country: 'スロバキア', gdpm: 86629, popk: 5421, gdpcap: 15980 }, { id: 49, country: 'バルバドス', gdpm: 4385, popk: 280, gdpcap: 15660 }, { id: 50, country: 'ウルグアイ', gdpm: 53107, popk: 3416, gdpcap: 15546 } ]; }