Ant Design中Spin组件使用(以表格加载为例)

import React, { Component } from 'react'
import { Table, Spin } from 'antd';
import axios from 'axios'

export default class Home extends Component {
    state = {
        selectedRowKeys: [], // 表格选择项Keys
        selectedRows: [], // 表格选择项Rows
        tableData: [],
        total: 0,
        tableLoading: false // 加载状态
    }

    getColumns = () => {
        return [
            {
                title: 'ID',
                dataIndex: 'id',
                width: 30,
            },
            {
                title: '标题',
                dataIndex: 'title',
                width: 500,
                render: (text, record) => <a href="javascript: void(0)" target="_self" onClick={() => this.handleShowDetailBlog(record.id)}>{text}</a>
            },
            {
                title: '内容',
                dataIndex: 'content',
                render(text, record) {
                    return <div dangerouslySetInnerHTML={{ __html: record.content }} style={{}} />
                }
            },
            {
                title: '发布时间',
                dataIndex: 'datetime'
            }
        ];
    }

    // 获取表格数据
    getData(pageNumber, pageSize) {
        this.setState({
            tableLoading: true
        })

        axios.get(`http://localhost:5555/api/blog_list/?pageSize=${pageSize}&pageNumber=${pageNumber}&sortName=id&sortOrder=desc&_=1595230808893`).then((resp) => {
            let ajaxData = [];
            for (let i = 0; i < resp.data.rows.length; i++) {
                ajaxData.push({
                    key: resp.data.rows[i].id,
                    id: resp.data.rows[i].id,
                    title: resp.data.rows[i].title,
                    content: resp.data.rows[i].content.replace(/<[^>]*>|<\/[^>]*>/gm, "").substring(0, 54),
                    datetime: resp.data.rows[i].datetime,
                });
            }

            this.setState({
                tableData: ajaxData,
                total: resp.data.total,
                tableLoading: false
            })
        }, (err) => {
            console.log(err);
            this.setState({
                tableLoading: false
            })
        });
    }

    onChange = (pageNumber, pageSize) => {
        this.pageNum = pageNumber;
        this.pageSize = pageSize;
        this.getData(pageNumber, pageSize);
    };

    onTableSelectChange = (selectedRowKeys, selectedRows) => {
        this.setState({ selectedRowKeys, selectedRows });
    };

    componentDidMount() {
        this.getData(1, 10);
    }

    render() {
        // 控制表格选择
        const rowSelection = {
            selectedRowKeys: this.state.selectedRowKeys,
            onChange: this.onTableSelectChange
        };

        return (
            <>
                <Spin spinning={this.state.tableLoading} tip="加载中......" size="large">
                    <Table
                        onRow={record => {
                            return {
                                onClick: event => { console.log(record) }, // 点击行
                                onDoubleClick: event => { },
                                onContextMenu: event => { },
                                onMouseEnter: event => { }, // 鼠标移入行
                                onMouseLeave: event => { },
                            };
                        }}
                        rowSelection={rowSelection}
                        columns={this.getColumns()}
                        dataSource={this.state.tableData}
                        pagination={{
                            current: this.pageNum,
                            total: this.state.total,
                            pageSizeOptions: [5, 10, 20, 50, 100],
                            defaultPageSize: 10,
                            showSizeChanger: true,
                            showQuickJumper: true,
                            showTotal: (total, range) => `共 ${total} 条`,
                            onChange: this.onChange
                        }}
                        bordered
                    >
                    </Table>
                </Spin>
            </>
        )
    }
}

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在整个项目全局使用 Ant Design Vue 的 Spin 组件,你可以创建一个全局组件,并将 Spin 组件作为其内容。 首先,在你的项目创建一个名为 `GlobalSpin.vue` 的新文件,内容如下: ```html <template> <div v-if="loading" class="global-spin"> <a-spin size="large" /> </div> </template> <script> export default { data() { return { loading: false } }, methods: { show() { this.loading = true; }, hide() { this.loading = false; } } } </script> <style scoped> .global-spin { position: fixed; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background-color: rgba(0, 0, 0, 0.5); z-index: 9999; } </style> ``` 在这个文件,我们创建了一个名为 `GlobalSpin` 的组件,并在其使用Ant Design Vue 的 Spin 组件。我们还添了 `show` 和 `hide` 方法来控制状态的显示和隐藏。 接下来,在你的主应用程序文件(通常是 `main.js`)全局注册这个组件: ```javascript import Vue from 'vue'; import GlobalSpin from './GlobalSpin.vue'; Vue.prototype.$spin = new Vue(GlobalSpin).$mount(); document.body.appendChild(Vue.prototype.$spin.$el); ``` 这段代码将创建一个全局的 `$spin` 对象,并将其挂到 Vue 原型上。然后,我们将组件的根元素添到 `body` 元素。 现在,你就可以在整个项目使用 `$spin` 对象来控制全局状态的显示和隐藏。如,在你的某个组件,可以调用 `$spin.show()` 来显示状态,调用 `$spin.hide()` 来隐藏状态。 希望这可以帮助到你!如果有任何其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值