背景
最近社内プロジェクトのVue2からVue3へのmigration作業をやっております。既存のVue2バージョンのプロジェクトにて、Vuetifyのdata table componentを使っていますが、Vue3の場合、最新のVutify3 Beta(vue3 version)を本番環境で使うのはまだ厳しいそうです:
しかもdata table componentはまだリリースされていない。それで、Vuetify2のdata table componentのAPIとUIを参照して、vue3-easy-data-table
というcomponentを作りました。私と同じくVutify3のdata table componentのリリースを待っている方がいらっしゃいましたら、まずこのvue3-easy-data-table
を使ってみたらどうでしょうか?
Repository linkはこちらです:https://github.com/HC200ok/vue3-easy-data-table
Website
使い方
Install
npm install vue3-easy-data-table
// or
yarn add vue3-easy-data-table
Regist
import Vue3EasyDataTable from 'vue3-easy-data-table';
import 'vue3-easy-data-table/dist/style.css';
const app = createApp(App);
app.component('EasyDataTable', Vue3EasyDataTable);
Use
<template>
<EasyDataTable
:headers="headers"
:items="items"
/>
</template>
<script lang="ts">
import type { Header, Item } from "vue3-easy-data-table";
export default defineComponent({
setup() {
const headers: Header[] = [
{ text: "Name", value: "name" },
{ text: "Height (cm)", value: "height", sortable: true },
{ text: "Weight (kg)", value: "weight", sortable: true },
{ text: "Age", value: "age", sortable: true }
];
const items: Item[] = [
{ "name": "Curry", "height": 178, "weight": 77, "age": 20 },
{ "name": "James", "height": 180, "weight": 75, "age": 21 },
{ "name": "Jordan", "height": 181, "weight": 73, "age": 22 }
];
return {
headers,
items
};
},
});
</script>
機能
- Buttons pagination
- Dense
- Item slot
- Multiple selecting
- Single field sorting
- Searching
- Server side paginate and sort
- Theme color
Buttons pagination
data:image/s3,"s3://crabby-images/b08f0/b08f0fcfa9fa91a74d01e4e672fd6bb1b0a0bf8f" alt=""
Dense
data:image/s3,"s3://crabby-images/5daca/5daca761760d7df1d115a76d2320be2a62df9510" alt=""
Item slot
data:image/s3,"s3://crabby-images/83e54/83e54620abd19d854971482536978a1c52683cee" alt=""
Multiple selecting
data:image/s3,"s3://crabby-images/2d51f/2d51ff0a268369c871a9dba31c775e387ecbe9d0" alt=""
Single field sorting
data:image/s3,"s3://crabby-images/3e028/3e02828db545399e266bbf37c46e1d803bdc54fd" alt=""
Searching
data:image/s3,"s3://crabby-images/47e94/47e945642fc15ca96d0ca844228c32f1c521fa08" alt=""
Server side paginate and sort
data:image/s3,"s3://crabby-images/f014b/f014b06455b8be992fddbc7e2c081a647fac6f35" alt=""
Theme color
data:image/s3,"s3://crabby-images/e92bc/e92bccb49562d5988294acc62fa67751f9707e66" alt=""
Documentation
上記のように、簡単にキャプチャとpreview linkを貼りましたが、詳しくはこちらのdocumentationを参照してください:https://github.com/HC200ok/vue3-easy-data-table/blob/main/README.md
最後に
利用される途中で不具合があたり、上記以外の欲しい機能があたりする場合、issueの提出をお願いいたします、また、pull requestも大歓迎です。