我可以更改所选文本的HTML吗?

时间:2012-07-28 04:36:55

标签: javascript jquery

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

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

enter image description here

将HTML作为

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

可以获取已经回答here的所选文本的HTML。

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

2 个答案:

答案 0 :(得分:3)

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

答案 1 :(得分: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