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:让光标显示在最后面