2

我们可以使用 javascript 更改网页选定部分的 HTML 或其属性吗?

例如,有一个随机网页:(显示了一部分)

在此处输入图像描述

用 HTML 作为

...<p>Sample paragraph</p>..

可以获得已在此处回答的所选文本的 HTML 。

但是,我可以更改所选文本的 html 吗?比如,在段落标签中添加一个 class 或 id 属性。

4

2 回答 2

3

jQuery wrapselection 插件听起来像您正在寻找的http://archive.plugins.jquery.com/project/wrapSelection。你所要求的不是直接可能的,插件通过在周围文本周围添加额外的节点来工作,这些节点可能不是 100% 可靠的(特别是在 IE6-8 中)

于 2012-07-28T04:43:39.240 回答
2

这是一个没有插件的工作示例。

http://jsfiddle.net/9HTPw/2/

function getSel() {
    var sel = null;
    if (
    typeof document.selection != "undefined" && document.selection 
                                   && document.selection.type == "Text") {
        sel = document.selection;
    } else if (
    window.getSelection && window.getSelection().rangeCount > 0) {
        sel = window.getSelection();
    }
    return sel;
}

var getSelectionStart = (function () {

    function createRangeFromSel(sel) {
        var rng = null;
        if (sel.createRange) {
            rng = sel.createRange();
        } else if (sel.getRangeAt) {
            rng = sel.getRangeAt(0);
            if (rng.toString() == "") rng = null;
        }
        return rng;
    }

    return function (el) {
        var sel = getSel(),
            rng, r2, i = -1;
        if (sel) {
            rng = createRangeFromSel(sel);
            if (rng) {

                if (rng.parentElement) {
                    if (rng.parentElement() == el) {
                        r2 = document.body.createTextRange();
                        r2.moveToElementText(el);
                        r2.collapse(true);
                        r2.setEndPoint("EndToStart", rng);
                        i = r2.text.length;
                    }
                } else {
                    if ( rng.startContainer && rng.endContainer 
                   &&  rng.startContainer == rng.endContainer 
                   && rng.startContainer == rng.commonAncestorContainer 
                   && rng.commonAncestorContainer.parentNode == el) {

                        //make sure your DIV does not have any inner element,
                        //otherwise more code is required in order to filter
                        //text nodes and count chars

                        i = rng.startOffset;
                    }
                }
            }
        }
        return i;
    };

})();


$("#content").on('mousedown', function () {
    $("#content").html(content)
});

var content = $("#content").html();

$("#content").on('mouseup', function () {
    var start = getSelectionStart(this);
    var len = getSel().toString().length;


    $(this).html(
            content.substr(0, start) + 
            '<span style=\"background-color: yellow;\">' +
            content.substr(start, len) + 
            '</span>' +
            content.substr(Number(start) + Number(len), content.toString().length));
});

参考资料: http ://bytes.com/topic/javascript/answers/153164-return-selectionstart-div

于 2012-07-28T06:07:30.830 回答