我已经这样做了一个星期。仍然无法找到答案。我试图只将一些关键字转换为链接而不是全部。例如,如果段落中的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>");
答案 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);
如果您想要全部,只需省略最大值,它应默认为所有关键字。