如何在保持当前内联样式的同时以编程方式将文本插入草稿 js 富文本字段?

IT技术 javascript reactjs draftjs
2021-05-25 18:07:07

当我单击带有某个符号的按钮时,我希望它将该符号放在文本字段中。

为了实现这一点,我使用了一个文本插入函数:

insertText(characterToInsert) {
    let editorState = this.state.editorState;

    const currentContent = editorState.getCurrentContent(),
        currentSelection = editorState.getSelection();

    let newContent = Modifier.replaceText(
        currentContent,
        currentSelection,
        characterToInsert
    );

    return EditorState.push(editorState, newContent, 'insert-characters');
}

当下标内联样式打开时,我希望它在那里放置一个下标文本。

我试着做类似的事情

if (this.isSubscriptOn()) {
    newContent = Modifier.applyInlineStyle(newContent, currentSelection, 'SUBSCRIPT');
}

但是,我不知道如何更改第二个参数,以便选择针对新放置的字符。

有没有更好的方法来解决这个问题?

1个回答

第一步是使用applyInlineStyle: function (contentState: ContentState, selectionState: SelectionState, inlineStyle: string)静态Modifier功能如您所见 - 它需要选择我们希望应用样式的区域。我们将使用以下set方法创建这样的样式immutable.js

const textToInsertSelection = currentSelection.set('focusOffset', currentSelection.getFocusOffset() + textToInsert.length);

然后我们将获得OrderedSet当前的内联样式并将它们中的每一个应用于上述选择:

let inlineStyles = editorState.getCurrentInlineStyle();
inlineStyles.forEach(inLineStyle => newContent = Modifier.applyInlineStyle(newContent, textToInsertSelection, inLineStyle));

如果我们停在这里,文本将在被选中时放入输入字段(蓝色矩形会出现在它周围)。为了避免这种行为,让我们强制选择插入文本的末尾:

newState = EditorState.forceSelection(newState, textToInsertSelection.set('anchorOffset', textToInsertSelection.getAnchorOffset() + textToInsert.length));

整个函数如下所示:

insertText(textToInsert) {
    let editorState = this.state.editorState;

    const currentContent = editorState.getCurrentContent();
    const currentSelection = editorState.getSelection();

    let newContent = Modifier.replaceText(
        currentContent,
        currentSelection,
        textToInsert
    );

    const textToInsertSelection = currentSelection.set('focusOffset', currentSelection.getFocusOffset() + textToInsert.length);

    let inlineStyles = editorState.getCurrentInlineStyle();

    inlineStyles.forEach(inLineStyle => newContent = Modifier.applyInlineStyle(newContent, textToInsertSelection, inLineStyle));

    let newState = EditorState.push(editorState, newContent, 'insert-characters');
    newState = EditorState.forceSelection(newState, textToInsertSelection.set('anchorOffset', textToInsertSelection.getAnchorOffset() + textToInsert.length));

    return newState;
}