Vue と Element-UI を使用して編集可能なデータ テーブルを実装する方法
Vue と Element-UI を使用して編集可能なデータ テーブルを実装する方法
はじめに:
Web 開発では、データ テーブルは大量のデータを表示できる非常に一般的なコンポーネントです。テーブル形式で、並べ替え、フィルタリング、編集などの操作を実行できます。この記事では、Vue と Element-UI を使用して編集可能なデータ テーブルを実装する方法を紹介します。
1. 準備
まず、Vue と Element-UI をインストールする必要があります。
1. Vue プロジェクトを作成する:
vue create editable-table cd editable-table
2. Element-UI の依存関係をインストールする:
npm install element-ui -S
3. Element-UI を main.js に導入する:
import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI)
2. データ テーブルの基本構造
Vue コンポーネントでは、Element-UI が提供する el-table コンポーネントを使用して基本的なデータ テーブルを作成し、el-table-column を使用してヘッダーとテーブルの列。
1. HelloWorld.vue ファイルに次のコードを追加します:
<template> <div> <el-table :data="tableData" style="width: 100%"> <el-table-column label="姓名" prop="name"></el-table-column> <el-table-column label="年龄" prop="age"></el-table-column> <el-table-column label="性别" prop="gender"></el-table-column> <el-table-column label="操作"> <template slot-scope="scope"> <el-button @click.native="handleEdit(scope.row)">编辑</el-button> </template> </el-table-column> </el-table> </div> </template> <script> export default { data() { return { tableData: [ { name: '小明', age: 18, gender: '男' }, { name: '小红', age: 20, gender: '女' }, { name: '小李', age: 22, gender: '男' } ] } }, methods: { handleEdit(row) { // 实现编辑功能 } } } </script> <style scoped> </style>
上記のコードでは、編集操作を実行するための el-button コンポーネントを追加しました。編集ボタンをクリックすると handleEdit メソッドが呼び出され、パラメータを通じて現在の行のデータを取得できます。
3. 編集機能を実装します
1. ダイアログ コンポーネントを追加します:
// HelloWorld.vue <template> <div> <el-dialog :visible.sync="dialogVisible" title="编辑数据"> <el-form :model="form" label-width="80px"> <el-form-item label="姓名"> <el-input v-model="form.name"></el-input> </el-form-item> <el-form-item label="年龄"> <el-input v-model="form.age"></el-input> </el-form-item> <el-form-item label="性别"> <el-input v-model="form.gender"></el-input> </el-form-item> </el-form> <div slot="footer"> <el-button @click="dialogVisible = false">取消</el-button> <el-button type="primary" @click="saveData">保存</el-button> </div> </el-dialog> <el-table :data="tableData" style="width: 100%"> <!-- ...省略其他代码... --> </el-table> </div> </template> <script> import { cloneDeep } from 'lodash' export default { data() { return { tableData: [ { name: '小明', age: 18, gender: '男' }, { name: '小红', age: 20, gender: '女' }, { name: '小李', age: 22, gender: '男' } ], dialogVisible: false, form: {} } }, methods: { handleEdit(row) { this.form = cloneDeep(row) this.dialogVisible = true }, saveData() { // 根据实际需求实现保存逻辑 this.dialogVisible = false } } } </script>
上記のコードでは、データ フレームを編集するためのダイアログをポップアップする el-dialog コンポーネントを追加しました。 。編集ボタンをクリックすると、行のデータがフォーム オブジェクトにコピーされ、ダイアログ ボックスの可視プロパティが true に設定されます。つまり、ダイアログ ボックスが開きます。
2. データ保存のロジックを実装します:
saveData メソッドでは、実際のニーズに応じて、変更されたデータをバックエンドまたはローカル ストレージに保存できます。
4. 概要:
Vue と Element-UI を使用すると、編集可能なデータ テーブルをすばやく構築できます。 el-table コンポーネントと el-table-column コンポーネントによって基本的なデータ テーブルを作成し、el-button コンポーネントと el-dialog コンポーネントによってデータ編集機能を実装しました。実際のプロジェクトでは、プロジェクト固有のニーズを満たすために、ニーズに応じてフォームをさらにカスタマイズおよび最適化できます。
上記は、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)

ホットトピック

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

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

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

Vue.jsでは、Lazy Loadingを使用すると、コンポーネントまたはリソースを必要に応じて動的にロードすることができ、初期ページの読み込み時間を短縮し、パフォーマンスを改善できます。特定の実装方法には、&lt; Keep-Alive&gt;および&lt;コンポーネントは&gt;コンポーネント。怠zyなロードは、FOUC(スプラッシュ画面)の問題を引き起こす可能性があり、不必要なパフォーマンスのオーバーヘッドを避けるために怠zyなロードが必要なコンポーネントにのみ使用する必要があることに注意してください。

Vueコンポーネントの合格値は、コンポーネント間でデータと情報を渡すメカニズムです。プロパティ(小道具)またはイベントを介して実装できます:プロップ:コンポーネントで受信するデータを宣言し、親コンポーネントにデータを渡します。イベント:$ EMITメソッドを使用して、VONディレクティブを使用してイベントをトリガーし、親コンポーネントでイベントを聞きます。

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

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

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