npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

element-crud-table

v1.4.0

Published

基于 vue3 + element-plus 构建的业务表格组件 ## 特性介绍

Downloads

2

Readme

element-crud-table

基于 vue3 + element-plus 构建的业务表格组件

特性介绍

  • 零件化,精细化控制,免去难以理解的配置化。内置12个功能组件(零件)!
  • 只对 element-plus 做增强,没有任何侵入代码。
  • 仅仅提供几个后端接口,就可以完成增删改查(接口返回需要有一些约定);加载、分页、搜索、新增、编辑就可以自动完成!
  • 支持所有表单元素

使用

安装与引入

安装

// pnpm
pnpm add element-crud-table
// yarn
yarn add element-crud-table

全部引入

// 引入element-plus
import {createApp} from 'vue'
import ElementPlus from "element-plus";
import "element-plus/lib/theme-chalk/index.css";
import zhCn from "element-plus/lib/locale/lang/zh-cn";

import ElementCrudTable from "element-crud-table";
import "element-crud-table/dist/style.css";
createApp(App)
    .use(ElementPlus, {locale: zhCn})
    .use(ElementCrudTable)
    .mount('#app')

按需引入

// 引入element-plus
import {createApp} from 'vue'
import ElementPlus from "element-plus";
import "element-plus/lib/theme-chalk/index.css";
import zhCn from "element-plus/lib/locale/lang/zh-cn";

import {CrudTable, CrudTableData, CrudTablePagination} from "element-crud-table";
import "element-crud-table/dist/style.css";
createApp(App)
    .use(ElementPlus, {locale: zhCn})
    .use(CrudTable)
    .use(CrudTableData)
    .use(CrudTablePagination)
    .mount('#app')

基本使用

1、简单的展示数据(不分页数据)。

  • 接口返回数据需如下:
{
  "data": []
}
  • 页面示例代码

<template>
  <crud-table>
    <crud-table-data url="http://localhost:5000/list">
      <el-table-column prop="id" label="id"></el-table-column>
      <el-table-column prop="name" label="姓名"></el-table-column>
    </crud-table-data>
  </crud-table>
</template>

2、添加分页,只需要使用 crud-table-pagination 包裹数据组件即可 。

  • 此时接口返回的数据必须如下所示:
{
  "data": {
    "records": [],
    "total": 156
  }
}
  • 页面示例代码

<template>
  <crud-table>
    <crud-table-pagination>
      <crud-table-data url="http://localhost:5000/list2">
        <el-table-column prop="id" label="id"></el-table-column>
        <el-table-column prop="name" label="姓名"></el-table-column>
      </crud-table-data>
    </crud-table-pagination>
  </crud-table>
</template>

3、添加头部与搜索栏

  • 页面示例代码

<template>
  <crud-table>
    <crud-table-header inline>
      <crud-table-search>
        <el-form-item prop="name">
          <el-input placeholder="姓名"/>
        </el-form-item>
        <el-form-item prop="age">
          <el-input placeholder="年龄"/>
        </el-form-item>
        <el-form-item prop="address">
          <el-input placeholder="地址"/>
        </el-form-item>
      </crud-table-search>
    </crud-table-header>
    <crud-table-pagination>
      <crud-table-data url="http://localhost:5000/list2">
        <el-table-column prop="id" label="id"></el-table-column>
        <el-table-column prop="name" label="姓名"></el-table-column>
      </crud-table-data>
    </crud-table-pagination>
  </crud-table>
</template>

4、完整示例:数据操作:新增、预览、编辑与删除

  • 代码

<template>
  <crud-table>
    <crud-table-header inline>
      <crud-table-search>
        <el-form-item prop="name">
          <el-input placeholder="姓名"/>
        </el-form-item>
        <el-form-item prop="age">
          <el-input placeholder="年龄"/>
        </el-form-item>
        <el-form-item prop="address">
          <el-input placeholder="地址"/>
        </el-form-item>
      </crud-table-search>
      <crud-table-action>
        <crud-table-btn-add url="http://localhost:5000/add"/>
      </crud-table-action>
    </crud-table-header>
    <crud-table-pagination>
      <crud-table-data url="http://localhost:5000/list2">
        <el-table-column prop="id" label="id"></el-table-column>
        <el-table-column prop="name" label="姓名"></el-table-column>
        <crud-table-handler>
          <crud-table-btn-preview/>
          <crud-table-btn-edit url="http://localhost:5000/edit"/>
          <crud-table-btn-del url="http://localhost:5000/del"/>
        </crud-table-handler>
      </crud-table-data>
    </crud-table-pagination>
    <crud-table-dialog>
      <el-form-item label="名称" prop="name">
        <el-input/>
      </el-form-item>
      <el-form-item label="年龄" prop="age">
        <el-input/>
      </el-form-item>
    </crud-table-dialog>
  </crud-table>
</template>

参考

可以在注册的时候,提供请求自定义请求方法,默认组件内部使用 fetch 进行网路请求


//你自定义的请求方法
import request from '/path'
app.use(ElementTablePlus,{requestMethod:request})


//按需引入时
import request from '/path'
import {CrudTable,CrudTableData} from 'element-crud-table'
app.use(CrudTable,{requestMethod:request})
    .use(CrudTableData)

1、CrudTable 【required

描述:顶层容器

attributes

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | gap | header、data、main 之间的间隙 | number | 0 |

events

| 方法 | 说明 | 回调 | | -------- | ------------------------------| ------ | | ready | 组件加载完成 | 组件实例方法 |

2、CrudTableData 【required

描述:数据引擎容器
内部使用 el-table-column 显示列

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | url | 数据列表 接口地址 | string | required | | autoLoad | 在组件挂载时自动加载数据 | boolean | true |

3、CrudTablePagination

描述:包裹CrudTableData,提供分页功能

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | pageSize | 每页数据大小 | number | 15 |

4、CrudTableHeader

描述:头部容器,有头部需求时可以使用

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | inline | 是否使用 inline-flex 布局 | boolean | false |

5、CrudTableSearch

描述:搜索表单容器,含有一个默认插槽,用于渲染表单
内部使用 el-form-item 包裹表单元素且要提供prop属性,提供的prop属性就是发送到后端的字段;
表单元素会自动绑定v-model,无需手动绑定

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | defaultFields | 表单项默认值 | object | | | formatter | 字段格式器,使用参考 | function 或 object | |

6、CrudTableDialog

描述:弹窗表单容器,含有一个默认插槽,用于渲染新增、编辑的表单
内部使用 el-form-item 包裹表单元素且要提供prop属性,提供的prop属性就是发送到后端的字段;
表单元素会自动绑定v-model,无需手动绑定

内部使用 el-form-item 包裹表单元素,并且必须提供 prop 属性

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | defaultFields | 表单项默认值 | object | | | formProps | el-form props | | | | inFormatter | 字段格式器,用于弹窗打开前,使用方式同formatter,参考 | function 或 object | | | outFormatter | 字段格式器,用于发送表单前,使用方式同formatter,参考 | function 或 object | | | ...rest | 支持el-dialog 的其他所有属性 | | |

7、CrudTableAction

描述:语义化标签、无特殊功能。头部按钮区:自定义的功能按钮将合理的布局在头部

8、CrudTableHandler

描述:行操作按钮容器,语义化、实际渲染的是一个 el-table-column
默认插槽可以拿到行数据

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | ...rest | 支持el-table-column 的其他所有属性 | | |

9、CrudTableBtnAdd

描述:新增按钮,内部绑定对应的功能

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | text | 按钮文字 | string | 新增 | | dialogTitle | 打开弹窗时的弹窗标题 | string | 新增 | | url | 提交新增网络请求的 api 路径 | string | required | | ...rest | 支持el-button 的其他所有属性 | | |

注意协商后端接口

假设 url 为 '/api/user' ,在提交请求时,内部不会做转换,请求方式为 'post',并携带表单请求体

10、CrudTableBtnEdit

描述:编辑按钮,内部绑定对应的功能

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | text | 按钮文字 | string | 编辑 | | dialogTitle | 打开弹窗时的弹窗标题 | string | 编辑 | | url | 提交 编辑 请求的 api 路径 | string | required | | echoUrl |回显 api路径; 可选,在打开编辑的时候,默认是从表格行中获取数据,若设置了此字段,则从此接口获取数据 | string | | | ...rest | 支持el-button 的其他所有属性 | | |

注意协商后端接口

假设 url 为 '/api/user' ,在提交请求时,内部会自动转换为 '/api/user/[id]',请求方式为 'put',并携带表单请求体
假设 echoUrl 为 '/api/user' ,内部会转换为 '/api/user/[id]',请求方式为 'get'

11、CrudTableBtnDel

描述:删除按钮,内部绑定对应的功能

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | text | 按钮文字 | string | 删除 | | url | 提交 删除 请求的 api 路径 | string | required | | ...rest | 支持el-button 的其他所有属性 | | |

注意协商后端接口

假设 url 为 '/api/user' ,在提交请求时,内部会自动转换为 '/api/user/[id]',请求方式为 'delete'

12、CrudTableBtnPreview

描述:预览按钮,显示的表单无法编辑

| 参数 | 说明 | 类型 | 默认值 | | -------- | ------------------------------| ------ | ------- | | text | 按钮文字 | string | 查看 | | dialogTitle | 打开弹窗时的弹窗标题 | string | 预览 | | echoUrl |回显 api路径; 可选,在打开预览的时候,默认是从表格行中获取数据,若设置了此字段,则从此接口获取数据 | string | | | ...rest | 支持el-button 的其他所有属性 | | |

注意协商后端接口

假设 echoUrl 为 '/api/user' ,内部会转换为 '/api/user/[id]',请求方式为 'get'