Javascript Bookmarklet 用链接替换文本

发布于 2024-12-28 12:54:33 字数 263 浏览 0 评论 0原文

我在 HTML 页面上有一些文本。 需要一个书签(无 jQuery),它将使用正则表达式查找文本片段,然后将其替换为以文本作为参数的链接

之前的示例:

aaa bbb ccc ddd

之后的示例:

aaa <a href="http:www.whatever.com?bbb">bbb</a> ccc ddd

假设我们正在寻找“bbb”

I have some text on an HTML page.
Need a bookmarklet (no jQuery) that will find a segment of the text using regex, then replace it with a link with the text as a parameter

Example before:

aaa bbb ccc ddd

Example after:

aaa <a href="http:www.whatever.com?bbb">bbb</a> ccc ddd

assuming we were looking for "bbb"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

薄凉少年不暖心 2025-01-04 12:54:33

此解决方案将爬行 DOM 搜索文档元素中的文本节点,跳过您想要的任何元素。例如,您可能想跳过 标签以及

(function(){
    // don't replace text within these tags
    var skipTags = { 'a': 1, 'style': 1, 'script': 1, 'iframe': 1 };

    // find text nodes to apply replFn to
    var findKW = function ( el, term, replFn ) {
        var child, tag;

        for (var i = el.childNodes.length - 1; i >= 0; i--) {
            child = el.childNodes[i];
            if (child.nodeType == 1) { // ELEMENT_NODE
                tag = child.nodeName.toLowerCase();
                if (!(tag in skipTags)) {
                    findKW(child, term, replFn);
                }
            } else if (child.nodeType == 3) { // TEXT_NODE
                replaceKW(child, term, replFn);
            }
        }
     };

    // replace terms in text according to replFn
    var replaceKW = function ( text, term, replFn ) {
        var match,
            matches = [];

        while (match = term.exec(text.data)) {
            matches.push(match);
        }
        for (var i = matches.length - 1; i >= 0; i--) {
            match = matches[i];

            // cut out the text node to replace
            text.splitText(match.index);
            text.nextSibling.splitText(match[1].length);
            text.parentNode.replaceChild(replFn(match[1]), text.nextSibling);
        }
    };

    var replTerm = prompt('Please enter term to replace');

    findKW(
        document.body, 

        // using \\b to only replace when the term is the whole word
        // e.g. if term is "bbb" then "aabbbccc" will not match
        new RegExp('\\b(' + replTerm + ')\\b', 'g'),

        // your replacement function, change URL accordingly
        function (match) {
          var link = document.createElement('a');
          link.href = 'http://google.com/#q=' + match;
          link.target = '_blank';
          link.innerHTML = match;
          return link;
        }
    );
}());        

这里它以书签形式最小化:

javascript:(function(){var a={a:1,style:1,script:1,iframe:1};var b=function(d,e,f){var g,h;for(var i=d.childNodes.length-1;i>=0;i--){g=d.childNodes[i];if(g.nodeType==1){h=g.nodeName.toLowerCase();if(!(h in a)){b(g,e,f)}}else if(g.nodeType==3){c(g,e,f)}}};var c=function(a,b,c){var d,e=[];while(d=b.exec(a.data)){e.push(d)}for(var f=e.length-1;f>=0;f--){d=e[f];a.splitText(d.index);a.nextSibling.splitText(d[1].length);a.parentNode.replaceChild(c(d[1]),a.nextSibling)}};var d=prompt("Please enter term to replace");b(document.body,new RegExp("\\b("+d+")\\b","g"),function(a){var b=document.createElement("a");b.href="http://google.com/#q="+a;b.target="_blank";b.innerHTML=a;return b})})()

将其复制到书签中并在任何页面上尝试!注意:搜索区分大小写,但您可以将“i”标志添加到正则表达式中以防止出现这种情况。

This solution will crawl the DOM search for text nodes within the document elements, skipping any elements you want. For example, you probably want to skip <a> tags, as well as <script> tags and others. This way, you won't replace element nodes or essential page functionality.

(function(){
    // don't replace text within these tags
    var skipTags = { 'a': 1, 'style': 1, 'script': 1, 'iframe': 1 };

    // find text nodes to apply replFn to
    var findKW = function ( el, term, replFn ) {
        var child, tag;

        for (var i = el.childNodes.length - 1; i >= 0; i--) {
            child = el.childNodes[i];
            if (child.nodeType == 1) { // ELEMENT_NODE
                tag = child.nodeName.toLowerCase();
                if (!(tag in skipTags)) {
                    findKW(child, term, replFn);
                }
            } else if (child.nodeType == 3) { // TEXT_NODE
                replaceKW(child, term, replFn);
            }
        }
     };

    // replace terms in text according to replFn
    var replaceKW = function ( text, term, replFn ) {
        var match,
            matches = [];

        while (match = term.exec(text.data)) {
            matches.push(match);
        }
        for (var i = matches.length - 1; i >= 0; i--) {
            match = matches[i];

            // cut out the text node to replace
            text.splitText(match.index);
            text.nextSibling.splitText(match[1].length);
            text.parentNode.replaceChild(replFn(match[1]), text.nextSibling);
        }
    };

    var replTerm = prompt('Please enter term to replace');

    findKW(
        document.body, 

        // using \\b to only replace when the term is the whole word
        // e.g. if term is "bbb" then "aabbbccc" will not match
        new RegExp('\\b(' + replTerm + ')\\b', 'g'),

        // your replacement function, change URL accordingly
        function (match) {
          var link = document.createElement('a');
          link.href = 'http://google.com/#q=' + match;
          link.target = '_blank';
          link.innerHTML = match;
          return link;
        }
    );
}());        

Here it is minimized in bookmarklet form:

javascript:(function(){var a={a:1,style:1,script:1,iframe:1};var b=function(d,e,f){var g,h;for(var i=d.childNodes.length-1;i>=0;i--){g=d.childNodes[i];if(g.nodeType==1){h=g.nodeName.toLowerCase();if(!(h in a)){b(g,e,f)}}else if(g.nodeType==3){c(g,e,f)}}};var c=function(a,b,c){var d,e=[];while(d=b.exec(a.data)){e.push(d)}for(var f=e.length-1;f>=0;f--){d=e[f];a.splitText(d.index);a.nextSibling.splitText(d[1].length);a.parentNode.replaceChild(c(d[1]),a.nextSibling)}};var d=prompt("Please enter term to replace");b(document.body,new RegExp("\\b("+d+")\\b","g"),function(a){var b=document.createElement("a");b.href="http://google.com/#q="+a;b.target="_blank";b.innerHTML=a;return b})})()

Copy that into a bookmark and try it out on any page! Note: search is case sensitive, but you can add the 'i' flag to the RegExp to prevent that.

我不咬妳我踢妳 2025-01-04 12:54:33

最简单的正则表达式:

document.body.innerHTML = document.body.innerHTML.replace(/bbb/ , '<a href="http://Google.com">bbb</a>');

更好:

document.body.innerHTML = document.body.innerHTML.replace(/(bbb)/ , '<a href="http://Google.com">$1</a>');

最好:

var srch = "bbb";
var rg = new RegExp("("+srch+")");
document.body.innerHTML = document.body.innerHTML.replace(rg , '<a href="http://Google.com">$1</a>');

正则表达式中的括号表示匹配的组。第二个参数中的“$1”是第一个匹配的组。

Simplest regex:

document.body.innerHTML = document.body.innerHTML.replace(/bbb/ , '<a href="http://Google.com">bbb</a>');

Better:

document.body.innerHTML = document.body.innerHTML.replace(/(bbb)/ , '<a href="http://Google.com">$1</a>');

Best:

var srch = "bbb";
var rg = new RegExp("("+srch+")");
document.body.innerHTML = document.body.innerHTML.replace(rg , '<a href="http://Google.com">$1</a>');

The parentheses in regexp signify a matched group. The "$1" in the second argument is the first matched group.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文