3

我使用以下代码显示 Ace 编辑器并突出显示文本范围。

JS:

let markers = [];
markers.push({startRow: 6, startCol: 5, endRow: 7, endCol: 6, className: 'replacement_marker', type: 'text' });

反应渲染():

    return (
        <div>
            <AceEditor
                mode="java"
                theme="github"
                name="UNIQUE_ID_OF_DIV"
                value={this.state.value}
                markers={markers}
            />
        </div>
    );

CSS:

.replacement_marker {
   position: absolute;
   background-color: #FFFF00;
}

使用此代码,编辑器突出显示整个第 6 行和第 7 行,而不将突出显示限制在第 5 - 6 列。

在此处输入图像描述 仅突出显示部分行而不突出显示整行的正确方法是什么?

4

1 回答 1

2

在我的例子中,这是由于一个糟糕的自定义 CSS 覆盖了标记层的左侧和宽度值。

.ace_marker-layer {
  > div:not(.ace_selection){
    width: 100% !important;
    border-radius: unset !important;
    left: 0 !important;
  }
}
于 2018-10-01T05:01:12.087 回答