Cha*_*lie 5 javascript jquery selection
如果我有以下HTML:
<div class="content">
Vivamus <span>luctus</span> urna sed urna ultricies ac tempor dui sagittis.
</div>
Run Code Online (Sandbox Code Playgroud)
我在上面运行一个事件mouseup,看到所选文本的范围:
$(".content").on("mouseup", function () {
var start = window.getSelection().baseOffset;
var end = window.getSelection().focusOffset;
if (start < end) {
var start = window.getSelection().baseOffset;
var end = window.getSelection().focusOffset;
} else {
var start = window.getSelection().focusOffset;
var end = window.getSelection().baseOffset;
}
console.log(window.getSelection());
console.log(start + ", " + end);
});
Run Code Online (Sandbox Code Playgroud)
我Vivamus从内容中选择单词,它将记录1, 8,因为这是选择的范围.
但是,如果我选择单词urna,它将记录15, 20,但不会考虑<span>HTML 的元素.
反正对focusOffset和baseOffset也算为HTML标签,而不是仅仅的文本?
更新
实例:http://jsfiddle.net/FLwxj/61/
使用clearSelection()函数和替换方法,我能够实现所需的结果.
var txt = $('#Text').html();
$('#Text').html(
txt.replace(/<\/span>(?:\s)*<span class="highlight">/g, '')
);
clearSelection();
Run Code Online (Sandbox Code Playgroud)
资料来源:
clearSelection():https://stackoverflow.com/a/6562764/1085891您可以在下面找到解决问题的方法.我按照代码效率的顺序放置它们.
工作方案
window.highlight = function() {
var selection = window.getSelection().getRangeAt(0);
var selectedText = selection.extractContents();
var span = document.createElement("span");
span.style.backgroundColor = "yellow";
span.appendChild(selectedText);
span.onclick = function (ev) {
this.parentNode.insertBefore(
document.createTextNode(this.innerHTML),
this
);
this.parentNode.removeChild(this);
}
selection.insertNode(span);
}
Run Code Online (Sandbox Code Playgroud)$(".content").on("mouseup", function () {
makeEditableAndHighlight('yellow');
});
function makeEditableAndHighlight(colour) {
sel = window.getSelection();
if (sel.rangeCount && sel.getRangeAt) {
range = sel.getRangeAt(0);
}
document.designMode = "on";
if (range) {
sel.removeAllRanges();
sel.addRange(range);
}
// Use HiliteColor since some browsers apply BackColor to the whole block
if (!document.execCommand("HiliteColor", false, colour)) {
document.execCommand("BackColor", false, colour);
}
document.designMode = "off";
}
function highlight(colour) {
var range, sel;
if (window.getSelection) {
// IE9 and non-IE
try {
if (!document.execCommand("BackColor", false, colour)) {
makeEditableAndHighlight(colour);
}
} catch (ex) {
makeEditableAndHighlight(colour)
}
} else if (document.selection && document.selection.createRange) {
// IE <= 8 case
range = document.selection.createRange();
range.execCommand("BackColor", false, colour);
}
}
Run Code Online (Sandbox Code Playgroud)其他有用的方案:
| 归档时间: |
|
| 查看次数: |
5051 次 |
| 最近记录: |