antd Table组件换行问题

1.强制换行

用css强行换行之后内容会重叠

用antd table提供的ellipsis会看不到全部内容

解决方法

将内容字符串按单位拆分成数组元素,返回一个由若干个字符串组成的数组

 /*
    @params str{ String} 要截取的字符串
    @params start { Number } 首次截取的开始索引,每次截取后递增
    @params end { Number } 首次截取的结束索引,每次截取后递增
    @params unit { Number } 每一组个数
*/
    // 将字符串转换成unit个字符为一组的数组
    const createArr = (str, start, end, unit) => {
        let arr = [] //保存每次截取后的字符串
        let counts = Math.ceil(str.length / unit) //循环截取的次数,向上取整
        for (let i = 0; i < counts; i++) {
            let newStr = str.substring(start, end)
            arr.push(newStr)
            start = end
            end += unit
        }
        return arr
    }

在columns的render中return出若干个dom元素

{
            title: '主诊',
            dataIndex: 'zz',
            key: 'zz',
            textAlign: 'center',
            render: (text) => {
                if (text) {
                    return (
                        createArr(text, 0, 12, 12).map(item => {
                            return (<li style={{ lineHeight: '1.5rem' }}>{item}</li>)
                        })
                    )
                }
            }
        },

效果

2.强制不换行

table的配置项

 columns={columns.map(item => { // 通过配置 给每个单元格添加不换行属性
                            const fun = () => ({ style: { whiteSpace: 'nowrap' } });
                            item.onHeaderCell = fun;
                            item.onCell = fun;
                            return item;
                        })}
                        scroll={{x:1600}}

效果是:如果长度过长会自己出现滚动条,内容不会重叠

根据需求选择对应的方法

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值