如何仅转换"一些"要链接的关键字而不是全部

时间:2015-01-23 03:01:22

标签: javascript keyword

我已经这样做了一个星期。仍然无法找到答案。我试图只将一些关键字转换为链接而不是全部。例如,如果段落中的7个关键字,我怎么能只转换3个呢?有人可以帮忙吗?请

目前这是我的代码。

(function($) {


       $.fn.replacetext = function(target, replacement) {
             // Get all text nodes:
             var $textNodes = this

                    .find("*")
                     .andSelf()
                     .contents()
                     .filter(function() {
                         return this.nodeType === 3 && 
                             !$(this).parent("a").length;
                     });

             $textNodes.each(function(index, element) {
                 var contents = $(element).text();
                 contents = contents.replace(target, replacement);
                 $(element).replaceWith(contents);

             });
        };
    })(jQuery);


     $("p").replacetext(/\bdress\b/gi, "<a href='http://www.google.com'>$&</a>");

1 个答案:

答案 0 :(得分:1)

我建议对函数使用限制,然后检查到目前为止匹配的项目集中匹配项的计数是否超过此限制。以下内容将修改第一个max项。

(function($) {
   $.fn.replacetext = function (target, replacement, max) {
       var limit = max || -1;

       // Get all text nodes:
       var $textNodes = this  
           .find("*")
           .andSelf()
           .contents()
           .filter(function () {
           return this.nodeType === 3 && !$(this).parent("a").length;
       });

       $textNodes.each(function (index, element) {
           var $element = $(element);
           var words = $element.text().split(/\b/);
           var matches = 0;
           var text = words.map(function (word, index) {
               if (matches >= limit) {
                   return word;
               }

               if (word.match(target)) {
                   ++matches;
                   return word.replace(target, replacement);
               }

               return word;
           });

           $element.replaceWith(text.join(''));
       });
   };
})(jQuery);

用作

$("p").replacetext(/dress/i, "<a href='http://www.google.com'>$&</a>", 3);

如果您想要全部,只需省略最大值,它应默认为所有关键字。