私はjs文字列を持っています...
var string = "Hi how are you <b>today</b>";
私は今、新しいjs文字列を持っています...
var newstring = "are today";
var string
don't matchからすべての単語を削除したいvar newstring
。また、それらの単語に関連付けられているタグがあれば保持したいと思います。
Example Result:
are <b>today</b>
私はjs文字列を持っています...
var string = "Hi how are you <b>today</b>";
私は今、新しいjs文字列を持っています...
var newstring = "are today";
var string
don't matchからすべての単語を削除したいvar newstring
。また、それらの単語に関連付けられているタグがあれば保持したいと思います。
Example Result:
are <b>today</b>
このようなことを行う簡単な方法がいくつかあります。それらが機能するかどうかは、これを何に使用するかによって異なりますが、おそらく次のようなものです。
var string = "Hi how are you <b>today</b>",
newstring = "are today",
words = newstring.split(' ');
for (var i=0; i<words.length; i++) {
var reg = new RegExp(words[i], 'gi');
string = string.replace(reg, '');
}
console.log(string);
var source = "Hi how are you <b>today</b>",
pattern = "are today",
res = [];
pattern.split(/\s+/).forEach(function( word ) {
source.split(/\s+/).forEach(function( sWord ) {
if( ~sWord.indexOf(word) ) res.push( sWord );
});
});
console.log(res.join(' '));
var str = 'Hi how are you <b>today</b>',
words = ['are', 'today']; //or 'are today'.split(' '),
regex = new RegExp('(<[a-zA-Z]*>)?(' + words.join('|') + ')(</[a-zA-Z]*>)?', 'g');
console.log(regex, str.match(regex), str.match(regex).join(' '));
ただし、すべての HTML タグをキャプチャするには、より複雑な正規表現が必要になります。
var string = "Hi how are you <b>today</b>",
newstring = "are today",
words= newstring.split(' ');
$.each(words, function(i, v) {
if(new RegExp(v, 'ig').test(string) && !new RegExp('<b>'+v+'</b>', 'ig').test(string)) {
string = string.replace(v,'');
}
});
console.log(string);