function longestWord(string) {
var str = string.split(" ");
var longest = 0;
var word = null;
for (var i = 0; i < str.length; i++) {
var checkedLetters = "";
for (var j = 0; j < str[j].length; j++) {
if (j == /[^a-zA-Z]/) {
checkedLetters += j;
}
if (longest < checkedLetters.length) {
longest = checkedLetters.length;
word = checkedLetters;
}
}
}
return word;
}
我使用正则表达式有什么问题吗?当我调用longestWord(“你好,我在这里”)时,我希望它返回“Hello”(不带逗号),但它返回null。
答案 0 :(得分:4)
刚刚写了这个小片段,可能会帮助你:
function longestWord(string){
return string.match(/[a-zA-Z]+/g)
.reduce(function(a,b){
return a.length>=b.length?a:b;
})
}
/[a-zA-Z]+/g
匹配字符串中的所有单词,并返回它们的数组。当在此RegEx上运行时,上面的测试字符串("Hello, I am here"
)将变为["Hello","I","am","here"]
。
一旦我拥有这个数组,只需循环查找最长的单词即可。我使用.reduce
完成了这项工作。
答案 1 :(得分:2)
您的代码中存在一些错误:
for (var j = 0; j < str[j].length; j++) {
应该是
for (var j = 0; j < str[i].length; j++) {
并且
if (j == /[^a-zA-Z]/) {
应该是:
if (/[a-zA-Z]/.test(str[i][j])) {
您的最终代码应为:
function longestWord(string) {
var str = string.split(" ");
var longest = 0;
var word = null;
for (var i = 0; i < str.length; i++) {
var checkedLetters = "";
for (var j = 0; j < str[i].length; j++) {
if (/[a-zA-Z]/.test(str[i][j])) {
checkedLetters += str[i][j];
}
}
if (longest < checkedLetters.length) {
longest = checkedLetters.length;
word = checkedLetters;
}
}
return word;
}
检查demo
答案 2 :(得分:1)
关于如何使用正则表达式的大(非拼写错误)问题是该方法是.test
; ==
将测试字符串是否等于正则表达式的字符串表示形式。
只需使用.match
和一点sort
魔法!
function longestWord(string){
var words = string.match(/\w+/g);
words.sort(function(a, b) { return b.length - a.length; });
// Firefox 22.0 promotion:
// words.sort((a, b) => a.length - b.length);
return words[0];
}
答案 3 :(得分:0)
您不需要使用Regex,只需使用.length搜索最长的字符串。
即
function longestWord(string) {
var str = string.replace(/[\.,-\/#!$%\^&\*;:{}=\-_`~()]/g,"").split(" ");
longest = str[0].length;
longestWord = str[0];
for (var i = 1; i < str.length; i++) {
if (longest < str[i].length) {
longest = str[i].length;
longestWord= str[i];
}
}
return longestWord;
}
编辑:你必须使用一些正则表达式...