draft.js:如何改变 draft.js 编辑框的高度

draft.js的<Editor />组件,实际占位只有一行,
想要输入文字只能点第一行,点击其他地方无法focus,
关键是 它还不接受style和class属性,无法改变高度
这里写图片描述

既然无法把它的高度撑开,那就换一个思路:
只要点击空白区域就能focus
那就和调整高度是一个效果


手动focus

先拿到editor的ref,

constructor(props) {
    super(props)        
    this.setDomEditorRef = ref => this.domEditor = ref
}

然后

focus(){
    this.domEditor.focus()
}
<div onClick={this.focus.bind(this)} style={{height:'100%'}}>
    <Editor ... />
</div>

就可以点击空白区域focus了


消除副作用

这还没完,
每次点击整个编辑器区域 都会focus,光标都会跑到第一行第一个,
这就没法编辑了,

一个简单的办法,如果我们的编辑器已经激活了,那么就不要执行
(假设我们的contentEditable只有一个)

focus(){
    if(document.activeElement.contentEditable != 'true') {
        this.domEditor.focus()
    }
}

移动光标位置

每次激活,光标都会跑到第一行第一个,怎么办呢
另一篇博文 draft.js:让光标显示在最后面

猜你喜欢

转载自blog.csdn.net/sinat_24070543/article/details/80384624
今日推荐