【问题标题】:Why does my replace work properly in javascript when I use "and" or "or" but not when I use "&" or "/" or "+"为什么当我使用“and”或“or”时我的替换在javascript中正常工作,但当我使用“&”或“/”或“+”时不能正常工作
【发布时间】:2019-11-07 00:35:45
【问题描述】:

我在 HTML 表单中输入了名字,有时用户会输入两个名字,我需要去掉第二个名字和用于连接它们的单词或字符。如果我使用单词“and”或单词“or”,我的 javascript 可以正常工作,并去掉第二个名称和用于加入它们的单词。但是,如果我使用与号 (&) 或加号 (+) 或正斜杠 (/),无论我如何编码,它只会去掉第二个名称的最后一个字符,而不是连接字符或除最后一个字符外,第二个名称后的任何字符。

我尝试过使用字符串函数、正则表达式、在 regex.com 上测试我的正则表达式(它们在那里工作并正确选择单词和连接词),我的正则表达式的十几种不同变体都可以在 regex 上正常工作, com 来选择我想要删除的文本,但这些都不适用于我的实际形式。

例如,如果我输入: “鲍勃和戴夫”我得到“鲍勃” - 正确 “鲍勃或戴夫”我得到“鲍勃” - 正确

但是如果我输入: “鲍勃和戴夫”我得到“鲍勃和戴夫” - 不正确 “Bob + Dave” 我得到“Bob + Dav” - 不正确 “Bob / Dave” 我得到“Bob” - 不正确但可以接受 “鲍勃,戴夫”我得到“鲍勃,戴夫” - 不正确

这是我使用的一些代码,前两种方法有几种不同的方法,后四种方法无效。

为“鲍勃和戴夫”工作:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search(/(\s)*\w+/gi)
var x = pattern.search("AND", z+1)
if (z < x) {
    alert('Please only enter ONLY ONE FIRST NAME')
    document.forms[0].first_name.focus();
    return document.forms[0].first_name.value=pattern.replace(/\s(AND)*\w+/gi, "");
}
}

为“鲍勃或戴夫”工作:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search(/\s(OR)*\w+/gi)
var x = pattern.search("OR", z+1)
if (z < x) {
    alert('Please only enter ONLY ONE FIRST NAME')
    document.forms[0].first_name.focus();
    return document.forms[0].first_name.value=pattern.replace(/\s(or)*\w+/gi, "");
}
}

这也适用于“Bob and Dave”并将相应的单词“and”更改为“or”,适用于“Bob or Dave”:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search("and")
var x = pattern.search("and")
if (z < x) {
    alert('Please only enter ONLY ONE FIRST NAME')
    document.forms[0].first_name.focus();
    return document.forms[0].first_name.value=pattern.slice(0, z);
}
}

但是,这适用于不正确但可接受的“Bob,Dave”,但不适用于“Bob & Dave”或“Bob / Dave”,当适当的字符被替换时:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search(/(,\s+)/gi);
var x = pattern.search((/(,\s+)/gi), z-1);
if (z < x) {
    alert('Please only enter ONLY ONE FIRST NAME');
    document.forms[0].first_name.focus();
    return document.forms[0].first_name.value=pattern.replace(/(,\s+)/gi);
}
}

这会产生与“&”和“/”相同的错误结果:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search(/(\s&)/gi);
var x = pattern.search(/(\s&\s.[a-z].+)/gi, z-1);
if (x < z) {
    alert('Please only enter ONLY ONE FIRST NAME');
    document.forms[0].first_name.focus();
    return document.forms[0].first_name.value=pattern.replace(/(\s&\s.[a-z].+)/gi, "");
}
}

所有的正则表达式都可以在 regex.com 上选择正确的文本,但在我的表单中从来没有用过,而且我几乎没有头发来沮丧。

为什么会发生这种情况,更重要的是我该如何解决。我尝试了在这个网站上找到的其他几种解决方案,例如:

function noExtraNames() {
var pattern=document.forms[0].first_name.value;
var z = pattern.search(/(,\s+)/gi);
var x = pattern.search((/(,\s+)/gi), z-1);
if (x < z) {
    alert('Please only enter ONLY ONE FIRST NAME');
    document.forms[0].first_name.focus();
    var s = document.forms[0].first_name.value;
    var n = s.indexOf('&');
    s = s.substring(0, n != -1 & n : s.length);
    return document.forms[0].first_name.value = s;
}
}

无所事事。

预期的输出是:Bob 实际输出为:Bob & Dav

【问题讨论】:

  • 您要从第一个空格中删除所有内容吗? return document.forms[0].first_name.value.replace(/\s.*/, '')?
  • This is probably relevant here。名称Jones, Tom 应该对Tom Jones 有效。另外,您是说网球运动员 Igor Andreev 不应该使用他的名字吗?乔治或者怎么样?
  • 第二次搜索中的z-1 意味着您再次找到相同的字符串,因此您的x 将始终等于z。 (除非找不到字符串,您从不测试)

标签: javascript regex


【解决方案1】:
const pattern = /(.*(?=(\s+(and|or)\s+)|(\s*[\&\+,\/\\])))|.*/i;
const patternMatch = str.match(pattern);
if (patternMatch[1]) {
  alert('Please only enter ONLY ONE FIRST NAME');
}
const replaceValue = patternMatch[0].trim();
document.forms[0].first_name.value = replaceValue;

我想这就是你需要的。

【讨论】:

    【解决方案2】:

    通过拆分正则表达式并返回第一项似乎会更好地处理这个问题。这种模式应该处理您帖子中提到的情况:

    var pattern = /(\s*[\+|&|\,|\/]\s*|\s+(and|or)\s+)/i;
    

    然后拆分并始终返回第一个元素。

    function noExtraNames(name) {
      var pattern = /(\s*[\+|&|\,|\/]\s*|\s+(and|or)\s+)/i;
      var items = name.split(pattern);
      if (items.length > 1) {
        console.log('Please only enter ONLY ONE FIRST NAME');
        return items[0];
      }
      return name;
    }
    
    let tests = [
      'Bob',
      'Billy Bob',
      'Bob and Dave',
      'Bob + Dave',
      'Bob & Dave',
      'Bob / Dave',
      'Bob, Dave',
      'Igor',
      'Andy',
      'Bob+Dave',
    ];
    
    for (let test of tests) {
      console.log(test, '===> ', noExtraNames(test));
    }

    【讨论】:

    • 这对名为 Igor 的人来说是失败的。它只输出“Ig”
    • 然后更新模式,检查andor 周围的空格,否则不需要空格
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-04-16
    • 2014-01-31
    • 2022-07-03
    • 2021-02-01
    • 2021-03-17
    相关资源
    最近更新 更多