ReactQuill字数限制方案

最近项目中有用到react-quill富文本,有一个需求是限制2000,但是react-quill本身并没有字数限制,所以我找到了一些解决方案

1. 使用deleteText

quill.on('text-change', function(delta, old, source) {
    if (quill.getLength() > limit) {
        quill.deleteText(limit, quill.getLength());
    }
});

在富文本的onChange事件里通过getLength()获取富文本字数,然后通过deleteText删除多出来的文字。
不过这种方法不是很好,会造成页面的卡顿

2. 监听键盘按下的事件onKeyDown

<ReactQuill
    onKeyDown={this.checkCharacterCount}
    onChange={(value) => this.props.onChange(value)}
/>

checkCharacterCount = (event) => {
    if (this.getCharacterText().length > this.props.maxCharacters && event.key !== 'Backspace') {
        event.preventDefault();
    }
}

监听键盘按下的事件,在监听事件中判断富文本字数是否超出限制的字数,如果超出且键盘按下的不是删除键,就禁止它的默认事件

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值