1 つのアプローチを次に示します。
function blacklister(el, words) {
if (!el || !words) {
return false;
}
else {
var text = el.textContent;
for (var i = 0, len = words.length; i < len; i++) {
if (text.test(new RegExp(words[i],'gi'))) {
el.className += 'black';
}
}
}
}
var m = document.getElementById('main'),
spans = m.getElementsByTagName('span'),
blacklist = ['ugly','bad'];
for (var i = 0, len = spans.length; i < len; i++) {
blacklister(spans[i],blacklist);
}
JS フィドルのデモ。
以下のOPが残したコメントに応じて編集され、Firefoxで上記を使用してエラーを報告します。
>
function blacklister(el, words) {
if (!el || !words) {
return false;
}
else {
var text = el.textContent;
for (var i = 0, len = words.length; i < len; i++) {
if (text.match(new RegExp(words[i],'gi'))) {
if (el.className.indexOf('black') == -1){
el.className += 'black';
}
}
}
}
}
var m = document.getElementById('main'),
spans = m.getElementsByTagName('span'),
blacklist = ['ugly','bad'];
for (var i = 0, len = spans.length; i < len; i++) {
blacklister(spans[i],blacklist);
}
JS フィドルのデモ。
参考文献: