本文主要是介绍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:让光标显示在最后面
这篇关于draft.js:如何改变 draft.js 编辑框的高度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!