Vue マルチ選択リスト コンポーネントの詳細な説明

Vue マルチ選択リスト コンポーネントの詳細な説明

マルチ選択は、すべてのオプションを一覧表示し、ユーザーが Ctrl/Shift キーを使用して複数選択できるようにする UI 要素です。これは一般的なデザイン要素です。場合によっては、スペースを節約するために、オプションをコンボ ボックスに折りたたむことがあります。ユーザーの操作を容易にするために、このコンポーネントには「すべて選択」と「すべてクリア」の 2 つのボタンも追加され、ユーザーは選択をすばやく選択またはクリアできます。この UI 要素は、以前は相関プロット アプリで使用されていました。

コンポーネントの登録

Multi-Select コンポーネントの登録は、カプセル化されたコードをコピーして貼り付けるだけです。ここでグローバル コンポーネントを登録することをお勧めします。

この要素は、2 つのモードを念頭に置いて設計されています。1 つ目は、上の例のグラフィックに示すように、新しいオプションをクリックするたびに古いオプションが保持され、新しいオプションが追加されるというものです。これはより一般的な方法です。 2 つ目は、新しいオプションをクリックするたびに、古いオプションがクリアされ、新しいオプションのみが保持されることです。この方法を使用して複数選択を行う場合は、Ctrl/Shift キーを使用する必要があります。この設計により、ユーザーはクリックするたびに古いオプションを簡単に削除できます。 2 番目の方法を使用する場合は、イベント@click.exact="AddToOrDeleteFromSelectedColumns" @click.exact="ClickOnColumnListItem"に置き換える必要があります。

<script type="text/x-template" id="複数選択テンプレート">
…
   <tr v-for = "(item,index) in columns" 
     @click.exact="選択した列に追加または削除"
     @click.shift.exact="選択した列に複数追加"
     @click.ctrl.exact="選択した列に追加または削除"
     :title="function(item){if(item.longname){return '短縮名: ' + item.name + '\n----------------\n' + item.longname}else{return item.name}}(item)"
     クラス="列リストエントリ">
   ...
   </tr>
</スクリプト>
<スクリプト>
Vue.component("複数選択", {
  テンプレート: "#multi-select-template",
…
</スクリプト>

コンポーネントの呼び出し

カスタムタグを直接追加するコンポーネントを呼び出します。

<複数選択:凡例名="凡例名"
       :columns="列"
       :selected_columns="選択された列"
       @update_selected_columns="選択された列の変更時">
</複数選択>

データの受け渡し

最後に、データをコンポーネントに渡す必要があります。 v-bind を使用すると、データを親コンポーネントのデータに動的にバインドできます。

props では、legend_name は Multi-Select で表示する必要がある名前にバインドされ、columns は Multi-Select のオプションにバインドされ、selected_columns は現在選択されている項目にバインドされます。さらに、Multi-Select コンポーネントの表示を更新するために、親インスタンスでイベント「onSelectedColumnsChange」を定義する必要もあります。

データ: 関数(){
   戻る {
     legend_name: "入力列",
     列: 
     [
       {"name":"A","longname":"銅"},
       {"name":"B","longname":"アルミニウム アルミニウム"},
       {"name":"C","longname":"カルシウム"},
       {"name":"D","longname":"カルシウム"},
   ]、
     選択された列: [],
   }
 },
... 
方法:{ 
   onSelectedColumnsChange:function(new_columns) {
     this.selected_columns = 新しい列;
   },
 },
...

これで、Vue マルチ選択リスト コンポーネントの詳細な説明は終了です。Vue マルチ選択リスト コンポーネントに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Vue Element フロントエンドアプリケーション開発ツリーリストコンポーネント
  • Vue ベースのタブリストカテゴリ切り替え商品リストコンポーネントのサンプルコード
  • Vue Element UI カスタム説明リストコンポーネント

<<:  Tomcatを自動的に開始するサービスとして設定するにはどうすればいいでしょうか?最も簡単な方法

>>:  CentOS 6.5 i386 インストール MySQL 5.7.18 詳細チュートリアル

推薦する

Vue+ElementUI で超大規模なフォーム例を処理する方法

最近、社内の業務調整により、以前の超長文のロジックが大幅に変更されたため、リファクタリングする予定で...

VMware Esxi のルート パスワードを忘れた後に正常に取得する方法

CentOS6 インストール ディスク (任意のバージョン) を準備するか、別の pnux インスト...

Windows での MySQL 8.0.12 のインストール手順と基本的な使用方法のチュートリアル

この記事では、WindowsでのMySQL 8.0.12のインストール手順と使用方法のチュートリアル...

iframe でページを開く方法

解決:リンクのターゲット属性値をターゲット フレームワーク名と同じに設定するだけです。具体的な手順:...

CSS で垂直方向の中央揃えを行う 7 つの方法の詳細なコード例

レイアウトを編集するとき、通常は水平センタリングと垂直センタリングを使用してデザインします。水平セン...

JS の Promise に中止関数を追加する方法

目次概要プロミスレースメソッド約束の再パッケージ化中止コントローラAxiosプラグインにはキャンセル...

HTML CSS の 3 つの一般的なスタイル セレクター

1: タグセレクタータグセレクターはすべてのタグに使用されます。ここでは p を例に挙げます。つまり...

Nginx Webサーバーのサンプルコードの設定方法の詳細な説明

概要今日は主に、NGINX を Web サーバーとして設定する方法を共有します。内容は次のとおりです...

テーブルの4辺を上下左右にスクロールするように固定する方法

質問:最近、プロジェクトの統計を行っていたときに、テーブルを上下にスクロールしたときにテーブルの先頭...

ページ下部のフッターを修正する方法(複数の方法)

フロントエンド Web エンジニアとして、ページ効果を作成するときに次の現象に遭遇したことがあるはず...

Linux resolv.conf の簡単な分析

1. はじめにresolv.conf は、さまざまなオペレーティング システムのドメイン ネーム シ...

40以上の美しいWebフォームデザイン例

Web フォームは、訪問者と Web サイト所有者間の主要なコミュニケーション チャネルです。フィー...

MySQL パーティション テーブルの基本入門チュートリアル

序文最近のプロジェクトでは、大量のデータを保存する必要があり、このデータには有効期限があります。クエ...

JavaScriptの基本的なインタラクションの詳細な説明

目次1. 要素の入手方法文書から入手ID取得クラス名 (className) を取得します。タグ名 ...

docker inspect コマンドの使用に関するヒント

説明と紹介Docker inspect は Docker クライアントのネイティブ コマンドであり、...