Vue と Element-UI を使用してデータ フィルタリングと検索機能を実装する方法
Vue と Element-UI を使用してデータ フィルタリングと検索機能を実装する方法
現代の Web 開発では、データ フィルタリングと検索機能は非常に一般的かつ重要な要件です。 Vue と Element-UI は現在非常に人気のあるフロントエンド フレームワークであり、データ フィルタリングと検索機能を簡単に実装できる強力なツールとコンポーネントを多数提供します。この記事では、Vue と Element-UI を使用してこれらの機能を実装する方法を紹介し、詳細なコード例を示します。
まず、データを表示するためのリストを準備する必要があります。 Vue コンポーネントを使用してこのリストを実装できます。表示およびフィルターしたいデータを含む「items」という配列があるとします。 v-for ディレクティブを使用して、この配列を反復処理し、各配列項目をリスト項目にレンダリングできます。コードは次のとおりです。
<template> <div> <ul> <li v-for="item in filteredItems" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { data() { return { items: [ { id: 1, name: 'Apple' }, { id: 2, name: 'Banana' }, { id: 3, name: 'Cherry' }, // ... ], searchKeyword: '', }; }, computed: { filteredItems() { // 根据搜索关键字和其他筛选条件过滤数组 return this.items.filter(item => { // 如果搜索关键字为空,返回所有数据 if (this.searchKeyword === '') { return true; } // 如果条件成立,返回满足条件的数据 return item.name.toLowerCase().includes(this.searchKeyword.toLowerCase()); }); }, }, }; </script>
上記のコードでは、computed 属性を使用して filteredItems を計算します。これにより、検索キーワードやその他のフィルター条件に基づいて項目配列がフィルターされます。テンプレートでは、v-for ディレクティブを使用して、filteredItems 配列を反復処理し、各配列項目をリスト項目にレンダリングします。
次に、ユーザーが検索キーワードを入力できるように入力ボックスを追加する必要があります。 Element-UI が提供する入力コンポーネントを使用して、この入力ボックスを実装できます。コードは次のとおりです。
<template> <div> <el-input v-model="searchKeyword" placeholder="请输入搜索关键字"></el-input> <ul> <li v-for="item in filteredItems" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { // ... }; </script>
上記のコードでは、v-model ディレクティブを使用して入力ボックスの値を searchKeyword にバインドします。ユーザーが検索キーワードを入力すると、searchKeyword の値が更新されます。
最後に、追加のフィルター条件を追加して、ユーザーがこれらの条件に基づいてデータをさらにフィルターできるようにします。 Element-UI が提供する Checkbox コンポーネントを使用して、これらの追加のフィルター条件を実装できます。コードは次のとおりです。
<template> <div> <el-input v-model="searchKeyword" placeholder="请输入搜索关键字"></el-input> <el-checkbox-group v-model="selectedOptions"> <el-checkbox label="Option 1"></el-checkbox> <el-checkbox label="Option 2"></el-checkbox> <el-checkbox label="Option 3"></el-checkbox> <!-- ... --> </el-checkbox-group> <ul> <li v-for="item in filteredItems" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { data() { return { // ... selectedOptions: [], }; }, computed: { filteredItems() { // 根据搜索关键字和其他筛选条件过滤数组 return this.items.filter(item => { // 如果搜索关键字为空,返回所有数据 if (this.searchKeyword === '') { return item.selectedOptions.length === 0; } // 如果条件成立,返回满足条件的数据 return ( item.name.toLowerCase().includes(this.searchKeyword.toLowerCase()) && this.selectedOptions.every(option => item.selectedOptions.includes(option)) ); }); }, }, }; </script>
上記のコードでは、v-model ディレクティブを使用して、Checkbox コンポーネントの値を selectedOptions 配列にバインドします。ユーザーがオプションをチェックすると、selectedOptions の値が更新されます。
この時点で、データのフィルタリングと検索機能が実装されました。ユーザーは入力ボックスに検索キーワードを入力し、追加のフィルタ条件をチェックして、表示されるデータをフィルタリングできます。 Vue と Element-UI を使用すると、これらの機能を簡単に実装できます。この記事のサンプルコードがお役に立てば幸いです。
以上がVue と Element-UI を使用してデータ フィルタリングと検索機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









HTMLテンプレートのボタンをメソッドにバインドすることにより、VUEボタンに関数を追加できます。 VUEインスタンスでメソッドを定義し、関数ロジックを書き込みます。

vue.jsでBootstrapを使用すると、5つのステップに分かれています。ブートストラップをインストールします。 main.jsにブートストラップをインポートしますブートストラップコンポーネントをテンプレートで直接使用します。オプション:カスタムスタイル。オプション:プラグインを使用します。

vue.jsでJSファイルを参照するには3つの方法があります。タグ;; mounted()ライフサイクルフックを使用した動的インポート。 Vuex State Management Libraryを介してインポートします。

Vue.jsの監視オプションにより、開発者は特定のデータの変更をリッスンできます。データが変更されたら、Watchはコールバック関数をトリガーして更新ビューまたはその他のタスクを実行します。その構成オプションには、すぐにコールバックを実行するかどうかを指定する即時と、オブジェクトまたは配列の変更を再帰的に聴くかどうかを指定するDEEPが含まれます。

vue.jsには、前のページに戻る4つの方法があります。$ router.go(-1)$ router.back()outes&lt; router-link to =&quot;/&quot; Component Window.history.back()、およびメソッド選択はシーンに依存します。

CSSアニメーションまたはサードパーティライブラリを使用して、VUEでマーキー/テキストスクロール効果を実装します。この記事では、CSSアニメーションの使用方法を紹介します。スクロールテキストを作成し、テキストを&lt; div&gt;をラップします。 CSSアニメーションを定義し、オーバーフローを設定します:非表示、幅、アニメーション。キーフレームを定義し、アニメーションの開始と終了時にtranslatex()を設定します。期間、スクロール速度、方向などのアニメーションプロパティを調整します。

ページネーションは、パフォーマンスとユーザーエクスペリエンスを向上させるために、大きなデータセットを小さなページに分割するテクノロジーです。 VUEでは、次の組み込みメソッドを使用してページを使用できます。ページの総数を計算します。TotalPages()トラバーサルページ番号:V-For Directive on Currentページを設定します。

Vue Devtoolsを使用してブラウザのコンソールでVueタブを表示することにより、Vueバージョンを照会できます。 NPMを使用して、「NPM List -G Vue」コマンドを実行します。 package.jsonファイルの「依存関係」オブジェクトでVueアイテムを見つけます。 Vue CLIプロジェクトの場合、「Vue -Version」コマンドを実行します。 &lt; script&gt;でバージョン情報を確認してくださいVueファイルを参照するHTMLファイルにタグを付けます。
