簡體   English   中英

JavaScript / jQuery - 檢查字符串是否包含其中一個關鍵字

[英]JavaScript/jQuery - Check if string contains one of the keywords

如何測試字符串是否包含所選關鍵字?

例如

var keywords = 'small, big, large'
var string = 'big brown bear';

function wordInString(string, keywords){
  return new RegExp( '\\b' + keywords + '\\b', 'i').test(string);
}

以上只適用於單個單詞,我需要能夠測試多個單詞,並且完全匹配。

將字符串拆分為單詞,並使用一組關鍵字

 function wordInString(string, keywords) { return string.split(/\\b/).some(Array.prototype.includes.bind(keywords)); } var keywords = ['small', 'big', 'large']; var result1 = wordInString('big brown bear', keywords); // true var result2 = wordInString('great brown bear', keywords); // false var result3 = wordInString('Big brown bear', keywords); // false console.log(result1, result2, result3); 

ES5(跨瀏覽器)版本

function wordInString(string, keywords) {
    return string.split(/\b/).filter(function(w) {
        return keywords.indexOf(w) !== -1;
    }).length > 0;
}

要歸還所有的話

 function wordInString(string, keywords) { return keywords.filter(function(x) { return this.includes(x) }, string.split(/\\b/)); } var keywords = ['small', 'big', 'large']; var result1 = wordInString('big brown bear large', keywords); // ["big", "large"] var result2 = wordInString('great brown bear', keywords); // [] var result3 = wordInString('Big brown bear', keywords); // [] console.log(result1); console.log(result2); console.log(result3); 

返回第一個匹配的單詞或空字符串

 function wordInString(string, keywords) { var r = ""; string.split(/\\b/).some( x => { return r = keywords.includes(x) ? x : ""; }) return r; } var keywords = ['small', 'big', 'large']; var result1 = wordInString('big brown bear large', keywords); // "big" var result2 = wordInString('great brown bear', keywords); // "" var result3 = wordInString('Big brown bear', keywords); // "" console.log(result1); console.log(result2); console.log(result3); 

使用一組關鍵字,並循環它們:

 var keywords = ['small', 'big', 'large']; console.log( wordInString("big brown bear", keywords) ); // true console.log( wordInString("it's small!", keywords) ); // true console.log( wordInString("it's larger than the other", keywords) );// false console.log( wordInString("it's black and red", keywords) ); // false function wordInString(string, keywords){ for(var i=0; i<keywords.length; i++){ if(new RegExp( '\\\\b' + keywords[i] + '\\\\b', 'i').test(string)){ return true; } } return false; } 

如果未找到,則返回匹配的字或預設字符串。

 function wordInString(string, keywords) { return string.split(/\\b/).filter(word => keywords.some(w => w === word))[0] || 'empty'; } var keywords = ['small', 'big', 'large']; var result1 = wordInString('big brown bear', keywords); // big var result2 = wordInString('tiny bear', keywords); // empty var result3 = wordInString('huge hairy bear', keywords); // empty console.log(result1, result2, result3); 

這是使用mapreduce函數和logical operators的不同解決方案。

 var keywords = 'small, big, large' var test1 = testString('big brown bear', keywords); //big var test2 = testString('great brown bear', keywords); // empty var test3 = testString('Big brown bear', keywords); // empty function wordInString(string, keywords){ return new RegExp( '\\\\b' + keywords + '\\\\b').test(string); } function testString(string,keywords){ var word='empty'; var result=keywords.split(',').map(function(item){ if(wordInString(string,item.trim())==true) word=item.trim(); return wordInString(string,item.trim()); }).reduce(function(curr,prev){ return curr || prev; }); return word; } console.log(test1) console.log(test2) console.log(test3) 

拆分關鍵字,然后在字符串上搜索關鍵字的indexOf

 var keywords = 'small, big, large' var string = 'big brown bear'; function wordInString(string, keywords) { return keywords.split(',').some(function(keyword) { return string.indexOf(keyword.trim()) == -1 ? false : true }); //return new RegExp('\\\\b' + keywords + '\\\\b', 'i').test(string); } console.log(wordInString(string, keywords)) console.log(wordInString(string, "xyz, abc")) console.log(wordInString("'a large bear'", "large, none")) 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM