javascript - 在 contenteditable 元素中插入链接

标签 javascript jquery hyperlink contenteditable

我正在开发一个简单的博客系统,并使用 contenteditable 以便用户可以设置文本格式。

到目前为止,一切都很顺利。

接下来我想要的是用户可以在文本中添加超链接。

用户必须选择(部分)文本并单击链接按钮。之后,将打开一个弹出窗口,用户应在其中输入链接地址。

当用户单击接受按钮时,我想将链接添加到他们在 contenteditable 中选择的文本。

由于我不知道如何执行此操作,因此如何实现此功能?

我的网站:http://82.170.147.49/blog/3/alpha-release

我网站的jsFiddle:http://jsfiddle.net/qhN9j/

最佳答案

document.execCommand() 在所有主要浏览器中为您执行此操作:

document.execCommand("CreateLink", false, "http://stackoverflow.com/");

要在显示链接对话框时保留选择,您可以使用以下函数:

function saveSelection() {
    if (window.getSelection) {
        sel = window.getSelection();
        if (sel.getRangeAt && sel.rangeCount) {
            var ranges = [];
            for (var i = 0, len = sel.rangeCount; i < len; ++i) {
                ranges.push(sel.getRangeAt(i));
            }
            return ranges;
        }
    } else if (document.selection && document.selection.createRange) {
        return document.selection.createRange();
    }
    return null;
}

function restoreSelection(savedSel) {
    if (savedSel) {
        if (window.getSelection) {
            sel = window.getSelection();
            sel.removeAllRanges();
            for (var i = 0, len = savedSel.length; i < len; ++i) {
                sel.addRange(savedSel[i]);
            }
        } else if (document.selection && savedSel.select) {
            savedSel.select();
        }
    }
}

jsFiddle 示例:http://jsfiddle.net/JRKwH/1/

更新

要获取创建的链接(如果有的话)是很棘手的。你可以使用我自己的 Rangy图书馆:

var sel = rangy.getSelection();
if (sel.rangeCount) {
    var links = sel.getRangeAt(0).getNodes([1], function(el) {
        return el.nodeName.toLowerCase() == "a";
    });
    alert(links.length);
}

...或类似以下内容:

function getLinksInSelection() {
    var selectedLinks = [];
    var range, containerEl, links, linkRange;
    if (window.getSelection) {
        sel = window.getSelection();
        if (sel.getRangeAt && sel.rangeCount) {
            linkRange = document.createRange();
            for (var r = 0; r < sel.rangeCount; ++r) {
                range = sel.getRangeAt(r);
                containerEl = range.commonAncestorContainer;
                if (containerEl.nodeType != 1) {
                    containerEl = containerEl.parentNode;
                }
                if (containerEl.nodeName.toLowerCase() == "a") {
                    selectedLinks.push(containerEl);
                } else {
                    links = containerEl.getElementsByTagName("a");
                    for (var i = 0; i < links.length; ++i) {
                        linkRange.selectNodeContents(links[i]);
                        if (linkRange.compareBoundaryPoints(range.END_TO_START, range) < 1 && linkRange.compareBoundaryPoints(range.START_TO_END, range) > -1) {
                            selectedLinks.push(links[i]);
                        }
                    }
                }
            }
            linkRange.detach();
        }
    } else if (document.selection && document.selection.type != "Control") {
        range = document.selection.createRange();
        containerEl = range.parentElement();
        if (containerEl.nodeName.toLowerCase() == "a") {
            selectedLinks.push(containerEl);
        } else {
            links = containerEl.getElementsByTagName("a");
            linkRange = document.body.createTextRange();
            for (var i = 0; i < links.length; ++i) {
                linkRange.moveToElementText(links[i]);
                if (linkRange.compareEndPoints("StartToEnd", range) > -1 && linkRange.compareEndPoints("EndToStart", range) < 1) {
                    selectedLinks.push(links[i]);
                } 
            }
        }
    }
    return selectedLinks;
}

jsFiddle:http://jsfiddle.net/JRKwH/3/

关于javascript - 在 contenteditable 元素中插入链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5605401/

相关文章:

javascript - Flowplayer HTML5 全屏播放

JQuery 环岛 - 每次环岛完成移动时获取所选 <lI> 的 ID

图片上的 HTML 链接仅显示在该图片下方

javascript - 如何为每个 block 设置一个事件类? [Javascript]

javascript - d3.js 流图上的 MNaN 和 NaN 坐标

javascript - 使用 JavaScript 更改背景图像

Java Android : Make a word (from a paragraph) into a button

javascript - 超链接到随机 HTML 页面

javascript - 具有 jQuery 动态表单的单个 div 中的多个文本字段

javascript - iframe 内容在被 mootools 操作时消失