ReactAntd(二十九) React-表格滚动以及固定指定的列

表格滚动,固定指定的列

  • fixed 固定指定的列

  • 代码如下

  • 我这里设置的宽度 800 高度 50 就有滚动条

import React, { useState } from 'react'
import { Table, ConfigProvider, Button, Space, message } from 'antd' // 引入ConfigProvider全局化配置
import zhCN from 'antd/es/locale/zh_CN'

function useHighTable2() {
  const [pagnationPage] = useState('bottomCenter') //改成BottomCenter
  function handleClickcaozuo(value) {
    message.success({
      content: JSON.stringify(value),
      className: 'custom-class',
      style: {
        marginTop: '20vh',
      },
    })
  }
  function handleClickDelete(value) {
    message.success({
      content: JSON.stringify(value),
      className: 'custom-class',
      style: {
        marginTop: '20vh',
      },
    })
  }
  const columns = [
    {
      title: '姓名',
      dataIndex: 'name',
      // specify the condition of filtering result
      // here is that finding the name started with `value`
      onFilter: (value, record) => record.name.indexOf(value) === 0,
      sorter: (a, b) => a.name.length - b.name.length,
      sortDirections: ['descend', 'ascend'],
      fixed: 'left',
    },
    {
      title: '年龄',
      dataIndex: 'age',
      defaultSortOrder: 'descend',
      sorter: (a, b) => a.age - b.age,
    },
    {
      title: '地址',
      dataIndex: 'address',
      filterMultiple: false,
      onFilter: (value, record) => record.address.indexOf(value) === 0,
      sorter: (a, b) => a.address.length - b.address.length,
      sortDirections: ['descend', 'ascend'],
    },
    {
      title: '操作',
      key: 'action',
      render: (text, record) => (
        <Space size="middle">
          <Button
            onClick={() => {
              handleClickcaozuo(record)
            }}
          >
            修改
          </Button>
          <Button
            onClick={() => {
              handleClickDelete(record)
            }}
          >
            删除
          </Button>
        </Space>
      ),
    },
  ]

  const data = [
    {
      key: '1',
      name: '张三',
      age: 32,
      address: '张三的个人信息',
    },
    {
      key: '2',
      name: '李四',
      age: 42,
      address: '李四的个人信息',
    },
    {
      key: '3',
      name: '王五不长',
      age: 32,
      address: '王五的个人信息',
    },
    {
      key: '4',
      name: '侯六名字长',
      age: 32,
      address: '侯六的个人信息',
    },
  ]
  function onChange(pagination, filters, sorter, extra) {
    console.log('params', pagination, filters, sorter, extra)
  }
  //分页
  const handleClick = (current, pageSize) => {
    console.log(current, pageSize)
    console.log(`当前页是${current}`)
    console.log(`每页条数${pageSize}`)
  }
  return (
    <ConfigProvider locale={zhCN}>
      <Table
        columns={columns}
        dataSource={data}
        onChange={onChange}
        scroll={{ x: 800, y: 50 }}
        pagination={{
          position: [pagnationPage],
          defaultCurrent: 1,
          defaultPageSize: 2,
          total: 50,
          onChange: handleClick,
        }}
      />
    </ConfigProvider>
  )
}

export default useHighTable2

文章作者: 雾烟云
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 雾烟云 !
  目录