премия
Баунти поступит в самое быстрое решение, как продемонстрировано jsPerf, в последних версиях Firefox, Chrome и Internet Explorer во время тестирования или ответ, наиболее полезный при создании такого решения по моему усмотрению. Mwahahaha!
Я буду в основном удовлетворен решением, которое берет все смещения s и необработанный <span>
и добавляет выделение к этому, так что parent.textContent = parent.textContent
за которым следует выполнение решения в обновленном списке смещений, будет повторное выделение, но это имеет неблагоприятную временную сложность, поэтому не является предпочтительным.
Связанные вопросы
- Перекрытие одной строки в другую проблему выделения строки
(не имеет перекрытия) - Как получить родительский элемент в строке HTML при заданном смещении?
(возникла из варианта этого вопроса)
У меня есть элемент, содержащий только текст, который я хотел бы выделить. У меня также есть массив [startline, startcol, endline, endcol]
который, зная длины каждой строки из .textContent
, я могу нормализовать [startoffset, endoffset]
. Как я могу выделить между каждой парой смещений s?
Эта проблема сложнее, чем кажется:
- в содержании не гарантируется отсутствие повторов (так что не найти/заменить), и
- подсветка должна в конечном счете выполняться на уже выделенном тексте, иногда пересекая текст, который уже выделен, и
- подсветка должна выполняться на основе индекса родительского элемента
.textContent
.
Определения
- выделить: поместить подмножество текста из элемента
textContent
в один или несколько<span class="highlighted">
без изменения значенияtextContent
родительского элемента, так что текст, который подсвечивается n раз, находится в пределах n вложенных<span class="highlighted">
элементы. - offset: неотрицательное целое число, представляющее число символов s до некоторой точки (которая находится между двумя символами s).
- character: экземпляр любого JavaScript дает вам значение в данном индексе строки
.textContent
(включая пробелы).
MCVE
function highlight(parent, startoff, endoff) {
// Erm...
parent.textContent;
}
// Test cases
var starts = [
5, 44, 0, 50, 6, 100, 99, 50, 51, 52
];
var ends = [
20, 62, 4, 70, 10, 100, 101, 54, 53, 53
];
for (var i = 0; i < 10; i += 1) {
highlight(document.getElementById("target"),
starts[i], ends[i]);
}
#target {
white-space: pre-wrap;
}
<span id="target">
'Twas brillig, and the slithy toves
Did gyre and gimble in the wabe:
All mimsy were the borogoves,
And the mome raths outgrabe.
"Beware the Jabberwock, my son!
The jaws that bite, the claws that catch!
Beware the Jubjub bird, and shun
The frumious Bandersnatch!"
He took his vorpal sword in hand:
Long time the manxome foe he sought --
So rested he by the Tumtum tree,
And stood awhile in thought.
And, as in uffish thought he stood,
The Jabberwock, with eyes of flame,
Came whiffling through the tulgey wood,
And burbled as it came!
One, two! One, two! And through and through
The vorpal blade went snicker-snack!
He left it dead, and with its head
He went galumphing back.
"And, has thou slain the Jabberwock?
Come to my arms, my beamish boy!
O frabjous day! Callooh! Callay!'
He chortled in his joy.
'Twas brillig, and the slithy toves
Did gyre and gimble in the wabe;
All mimsy were the borogoves,
And the mome raths outgrabe.
</span>