Ant Table组件

http://www.cnblogs.com/hujunzheng/p/5689650.html

React中使用Ant Table组件

v一、Ant Design of React

  http://ant.design/docs/react/introduce

v二、建立webpack工程

    webpack+react demo下载

    项目的启动,参考

v三、简单配置

  1.工程下载下来之后,在src目录下新建目录“table”,新建app.js,内容如下。

import React from ‘react‘;
import ReactDOM from ‘react-dom‘;
import ExampleTable from ‘./ExampleTable‘;
import ‘antd/dist/antd.css‘;
ReactDOM.render
(
   <ExampleTable />,
   document.body
);

  注:记住引入antd.css, 否则Table组件无法正常显示。

  2.新建ExampleTable.js, 内容如下。

import { Table } from ‘antd‘;
import React from ‘react‘;

class ExampleTable extends React.Component {
  constructor(props) {
      super(props);
      this.showCurRowMessage = this.showCurRowMessage.bind(this);
  }
  componentDidMount() {

  }

  //展示当前行信息
  showCurRowMessage(record){
    alert("key:"+record.key + " name:"+record.name + " age:" + record.age + " address:" + record.address + " description:" + record.description);
  }

  render() {
    let self = this;

    const columns = [
      { title: ‘姓名‘, dataIndex: ‘name‘, key: ‘name‘ },
      { title: ‘年龄‘, dataIndex: ‘age‘, key: ‘age‘, render: (text, record, index) => (Math.floor(record.age/10))*10+"多岁"},
      { title: ‘住址‘, dataIndex: ‘address‘, key: ‘address‘ },
      { title: ‘描述‘, dataIndex: ‘description‘, key: ‘description‘ },
      { title: ‘操作‘, dataIndex: ‘‘, key: ‘operation‘, render: function(text, record, index) {
          alert(text.operation + " " + record.operation)
          return <a href="#" name="delete" onClick={function() { self.showCurRowMessage(record)} } >信息</a>; } },
      //精简写法
      //{ title: ‘操作‘, dataIndex: ‘‘, key: ‘operation‘, render: (text, record, index) => <a href="#" name="delete" onClick={() => self.showCurRowMessage(record)}>信息</a> },
    ];

    const data = [
        { key: 1, name: ‘hyw‘, age: 32, address: ‘西湖区湖底公园1号‘, description: ‘我是hyw,今年32岁,住在西湖区湖底公园1号。‘, children:[
          { key: 1.1, name: ‘fas‘, age: 32, address: ‘西湖区湖底公园1号‘, description: ‘我是fas,今年32岁,住在西湖区湖底公园1号。‘ },
          { key: 1.2, name: ‘wyz‘, age: 42, address: ‘西湖区湖底公园2号‘, description: ‘我是wyz,今年42岁,住在西湖区湖底公园2号。‘ },
          { key: 1.3, name: ‘ldz‘, age: 32, address: ‘西湖区湖底公园3号‘, description: ‘我是ldz,今年32岁,住在西湖区湖底公园3号。‘ },
        ]},
        { key: 2, name: ‘lkx‘, age: 32, address: ‘西湖区湖底公园1号‘, description: ‘我是lkx,今年32岁,住在西湖区湖底公园1号。‘ },
        { key: 3, name: ‘mnk‘, age: 42, address: ‘西湖区湖底公园2号‘, description: ‘我是mnk,今年42岁,住在西湖区湖底公园2号。‘ },
        { key: 4, name: ‘xyt‘, age: 32, address: ‘西湖区湖底公园3号‘, description: ‘我是xyt,今年32岁,住在西湖区湖底公园3号。‘ },
      ];

    const rowSelection = {
      onChange(selectedRowKeys, selectedRows) {
        console.log(`selectedRowKeys: ${selectedRowKeys}`, ‘selectedRows: ‘, selectedRows);
      },
      onSelect(record, selected, selectedRows) {
        console.log(record, selected, selectedRows);
      },
      onSelectAll(selected, selectedRows, changeRows) {
        console.log(selected, selectedRows, changeRows);
      },
    };

    return (
      <div>
        <Table columns={columns}
          rowSelection={rowSelection}
          dataSource={data}
          className="table"
        />
      </div>
    );

  }
}

module.exports = ExampleTable;

  3.修改入口地址

  打开webpack.config.js,修改entry配置。

  entry: [
      ‘webpack/hot/only-dev-server‘,
      "./src/table/app.js"
    ],

v四、Table组件属性

v1.Table

参数 说明 类型 默认值
rowSelection 列表项是否可选择,配置项 Object null
pagination 分页器,配置项参考 pagination,设为 false 时不显示分页 Object  
size 正常或迷你类型,default or small String default
dataSource 数据数组 Array  
columns 表格列的配置描述,具体项见下表 Array -
rowKey 表格行 key 的取值,可以是字符串或一个函数 String or Function(record, index):string ‘key‘
rowClassName 表格行的类名 Function(record, index):string -
expandedRowRender 额外的展开行 Function -
defaultExpandedRowKeys 默认展开的行 Array -
expandedRowKeys 展开的行,控制属性 Array -
onChange 分页、排序、筛选变化时触发 Function(pagination, filters, sorter)  
loading 页面是否加载中 Boolean false
locale 默认文案设置,目前包括排序、过滤、空数据文案 Object filterConfirm: ‘确定‘ 
filterReset: ‘重置‘ 
emptyText: ‘暂无数据‘ 
默认值
indentSize 展示树形数据时,每层缩进的宽度,以 px 为单位 Number 15
onRowClick 处理行点击事件 Function(record, index) -
useFixedHeader 是否固定表头 Boolean false
bordered 是否展示外边框和列边框 Boolean false
showHeader 是否显示表头 Boolean true
footer 表格底部自定义渲染函数 Function(currentPageData)  
scroll 横向或纵向支持滚动,也可用于指定滚动区域的宽高度:{{ x: true, y: 300 }} Object -

v2.Column

  列描述数据对象,是 columns 中的一项。

参数 说明 类型 默认值
title 列头显示文字 String or React.Element -
key React 需要的 key,建议设置 String -
dataIndex 列数据在数据项中对应的 key,支持 a.b.c 的嵌套写法 String -
render 生成复杂数据的渲染函数,参数分别为当前行的值,当前行数据,行索引,@return里面可以设置表格行/列合并 Function(text, record, index) {} -
filters 表头的筛选菜单项 Array -
onFilter 本地模式下,确定筛选的运行函数 Function -
filterMultiple 是否多选 Boolean true
filterDropdown 可以自定义筛选菜单,此函数只负责渲染图层,需要自行编写各种交互 React.Element -
sorter 排序函数,本地排序使用一个函数,需要服务端排序可设为 true Function or Boolean -
colSpan 表头列合并,设置为 0 时,不渲染 Number  
width 列宽度 String or Number -
className 列的 className String -
fixed 列是否固定,可选 true(等效于 left) ‘left‘ ‘right‘ Boolean or String false
filteredValue 筛选的受控属性,外界可用此控制列的筛选状态,值为已筛选的 value 数组 Array -
sortOrder 排序的受控属性,外界可用此控制列的排序,可设置为 ‘ascend‘‘descend‘ false Boolean or String -

v3.rowSelection

  选择功能的配置。

参数 说明 类型 默认值
type 多选/单选,checkbox or radio String checkbox
selectedRowKeys 指定选中项的 key 数组,需要和 onChange 进行配合 Array []
onChange 选中项发生变化的时的回调 Function(selectedRowKeys, selectedRows) -
getCheckboxProps 选择框的默认属性配置 Function(record) -
onSelect 用户手动选择/取消选择某列的回调 Function(record, selected, selectedRows) -
onSelectAll 用户手动选择/取消选择所有列的回调 Function(selected, selectedRows, changeRows) -

v五、数据获取

  开始使用table组件时,不知道如何获取这一行的数据,第一种方法是配置rowSelection,在onSelect函数被调用的时候,可以获取当前行以及其子行的数据。第二种方法是配置Column中的render属性,这个属性对应一个函数,fun(text, record, index){}, 这是个渲染函数,参数分别为当前行的值,当前行数据,行索引,return可以决定表格里最终存放的值。

  本例中,表格中“操作”这一列就是通过render渲染实现,render时我们可以获取到当前行数据的引用record,并为这一列的每个表格的内容绑定了点击事件,点击之后alert当前行的数据。效果如下图所示。

v六、博客新增标签

  博客中新增了“打赏”标签,就在右下方。前几天看见一个博客有这样的“打赏”标签,于是模仿着做了一个,可以自行配置。由于是今天完成的,就在这里简单的介绍一下如何在自己的博客里引用这个功能。

  进入自己的博客, 依次点击“管理”, 设置。在“页首Html代码”中加入下面的引用。

<!-- 扫码打赏 -->
<script type="text/javascript">window.reward_config={align: "right", top: "50%", animate: true, alipay: "http://images.cnblogs.com/cnblogs_com/hujunzheng/855447/o_alipay.jpg", webChat: "http://images.cnblogs.com/cnblogs_com/hujunzheng/855447/o_webChat.png"};with(document)0[(getElementsByTagName(‘head‘)[0]||body).appendChild(createElement(‘script‘)).src=‘http://files.cnblogs.com/files/hujunzheng/my_reward.js‘];</script>

  注:注意支付方式要改成自己的,引用的my_reward.js可以下载到本地,然后存放到自己博客的文件管理中。

  更详细的介绍请参考“打赏”标签中的“了解更多”, 或者访问 打赏demo 。

时间: 2024-11-06 12:43:44

Ant Table组件的相关文章

React中使用Ant Table组件

一.Ant Design of React http://ant.design/docs/react/introduce 二.建立webpack工程 webpack+react demo下载 项目的启动,参考 三.简单配置 1.工程下载下来之后,在src目录下新建目录“table”,新建app.js,内容如下. import React from 'react'; import ReactDOM from 'react-dom'; import ExampleTable from './Exam

使用 antd Table组件, 异步获取数据

使用React.js + Redux + antd 制作CMS 后台内容管理系统,分享一点点积累,欢迎讨论. 在this.state中初始化数据: this.state = { pageNum:1, /*翻页查询*/ pageSize:10, /*分页查询*/ activePage: 1, /*默认显示一页*/ selectedRowKeys: [], // 这里配置默认勾选列 loading: false, /*antd*/ selectedRow:[] } 在制作过程中,根据需要把antd的

关于MUI v0.18.0版本 Table组件里的复选框不能选的解决方案

前段时间在用MUI的时候,Table组件出现复选框不能选的bug(描述: 点击复选框,点击事件会触发,复选框勾选状态无变化). 解决方法: 用CheckBox组件代替Table组件自带的复选框. 解决思路: 1.将CheckBox分为两种,一种是表头里的全选框(以下称全选框),一种是列表行里普通的复选框(以下称普通框): 2.将普通框进行单独封装(原因: 1.便于单个普通框自己管理自己的勾选状态,2.当全选框的勾选状态发生变化时,可以通过props将全选框的状态赋给它,从而实现全选的功能): 关

ireport5.6使用table组件,如何用table显示javaBean数据源

1.从组件面板添加一个table组件到报表中. 2.设计table的字段头. 合并操作 1. 2. 删除你不需要的列 新增你的合并列 3.在报表Parameters里新增一个参数dets(java.util.List) 4.配置table数据集 a.重命令数据集(方便) 右键->属性,即可修改. b.添加一个Parameters 新增一个table1(net.sf.jasperreports.engine.JRDataSource) c.手动配置代码,把dets参数传递给table1接收 <d

微信小程序简易table组件实现

前提:微信小程序自1.6.3基础库版本库开始支持简洁组件,之前的版本因不支持,故在引用组件处默认为空节点.关于微信小程序已有模板为何还需构建组件?一是因为组件可以更方便的自定义并绑定行为,二是在其他页面引用时,无需通过import,只需在该页面json文件下配置usingComponents属性即可.(原本想在app.json文件里配置这个属性,从此一劳永逸,但目前貌似还不支持,至少我尝试的时候还不行-.-) 思路:主要是将table的head和tbody部分的数据抽象出来,使之只需要传值就可直

Element ui 中使用table组件实现分页记忆选中

我们再用vue和element-ui,或者其他的表格的时候,可能需要能记忆翻页勾选,那么实现以下几个方法就ok了 首先定义个data值 data () { return { multipleSelectionAll: [], // 所有选中的数据包含跨页数据 idKey: 'personId' // 标识列表数据中每一行的唯一键的名称(需要按自己的数据改一下) } } 方法中定义以下: methods : { // 设置选中的方法 setSelectRow() { if (!this.multi

vue.js table组件封装

table组件 和 分页组件来自iview,在这里我根据公司业务再次做了一次封装,使用slot进行内容分发,可以随意放置input输入框和button按钮 ,再使用props向子组件传递参数,使用emit属性向父组件传递事件,代码如下 <子组件> <template> <div style=""> <div class="search-bar run-search-bar" style="background:no

iview修改table组件实现循环向上滚屏

前提,最近项目中需要实现table的滚屏效果,并且使用的是iview的table组件,踩坑,填坑如下. 1.首先找到Table组件中的table,就是这个class:ivu-table-body template部分代码 1 div class="headcol" > 2 <Table border :columns="columns7" :data="data6" ></Table> 3 </div>

iview Table组件使用过滤器时无法加载表头解决办法

title: iview Table组件使用过滤器时无法加载表头解决办法 date: 2018-10-01 15:08:50 tags: JavaScript 前端 vue iview 所遇到的问题 使用iview搭建社团用人员管理时,Table组件的columns中filters属性设置为Vue data 中的另一个对象 如下: data() { groupFilter: [], memberCol: [ { title: "组别", render: (h, params) =>