B2B2C商城系统-Table组件封装代码分享

摘要:流行的电商系统的商家中心、管理中心,理表格使用频率高,减少关于table的业务代码,且便于后期统一修改,后期维护。本文以Javashop电商系统为例介绍基于element中table组件进行二次简单的封装

一 table组件需求

  1. 搜索栏可选

  2. 包含分页

二 封装代码

首先在ui-components新建一个table文件夹
在这里插入图片描述
在同级的index.js里导入导出

import Vue from 'vue'  
import Tabel from './src/main'  
  
Tabel.install = () => {  
  Vue.component(Tabel.name, Tabel)  
}  
  
export default Tabel

props 允许父组件传递数据给子组件;并且对于父组件传递过来的参数应该加一些检验规则,比如数据类型type,默认值default(对象和数组的默认值必须通过函数返回)

props: {
  /** 是否显示斑纹 */
  stripe: {
    type: Boolean,
    default: true
  },
  /** 行数据的 Key */
  rowKey: {
    type: [String,Function],
    default: null
  },
  /** 是否显示工具栏 */
  toolbar: {
    type: Boolean,
    default: true
  },
  /** 是否显示操作提示 */
  tips: {
    type: Boolean,
    default: false
  },
  /** 是否显示分页 */
  pagination: {
    type: Boolean,
    default: true
  },
  /** 表格数据 */
  tableData: {
    default: () => ([])
  },
  /** 加载状态 */
  loading: {
    type: Boolean,
    default: false
  },
  /** 当选择项发生变化 */
  selectionChange: {
    type: Function,
    default: () => {}
  }
}

搜索栏是否可选实现:默认是显示,参数值为true;传递参数toolbar,可设置是否显示搜索栏,

分页功能:默认显示分页功能,参数值为rue;传递参数pagination,可设置是否显示分页

调用table组件

只需要在调用组件的地方,写上组件名字的标签即可,同时在标签上可以设置一些参数,传递给table组件

<en-table-layout
  toolbar
  pagination
  :tableData="tableData"
  :loading="loading">
  </en-table-layout>

这样一个简单table组件封装就完成了

易族智汇(javashop)原创文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kingapex1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值