4

我有这个字符串:

var a='abc123#xyz123';

我想构建 2 个正则表达式替换函数:

1)用( 包括'#')替换所有有未来的字符'#''*'

所以结果应该是这样的:

'******#xyz123'

2)替换所有没有未来的字符'#'- 用'*' (不包括'#')

所以结果应该是这样的:

'abc123#******'

我尝试了什么:

对于积极的前瞻性:

var a='abc123#xyz123';
alert(a.replace(/(.+(?=#))+/ig,'*'));  //*#xyz123 --wrong result since it is greedy...

问题 :

如何使我的正则表达式按预期工作?

4

3 回答 3

5

第一部分使用前瞻:

repl = a.replace(/.(?=[^#]*#)/g, "*");
//=> "******#xyz123"

解释:

此正则表达式使用前瞻查找后面的任何字符#并将其替换为*.

第二部分使用替换回调:

repla = a.replace(/#(.*)$/, function(m, t) { return m[0] + t.replace(/./g, '*'); } );
//=> abc123#******

解释:

此代码在#. 回调函数内部是用星号替换每个字符。

于 2013-10-29T13:41:11.550 回答
1

您可以使用indexOfandsubstr来代替:

function maskBeforeAfter(before, str, character, maskCharacter) {
    character = character || '#';
    maskCharacter = maskCharacter || '*';

    var characterPosition = str.indexOf(character);
    if (characterPosition > -1) {
        var mask = '';
        if (before) {
            for (var i = 0; i < characterPosition; i++) {
                mask += maskCharacter;
            }
            return mask + str.substr(characterPosition);
        } else {
            for (var i = 0; i < str.length - characterPosition - 1; i++) {
                mask += maskCharacter;
            }
            return str.substr(0, characterPosition + 1) + mask;
        }
    }
    return str;
}

function maskBefore(str, character, maskCharacter) {
    return maskBeforeAfter(true, str, character, maskCharacter);
}

function maskAfter(str, character, maskCharacter) {
    return maskBeforeAfter(false, str, character, maskCharacter);
}

> var a = 'abc12345#xyz123';

> maskBefore(a);
"********#xyz123"

> maskAfter(a);
"abc12345#******"
于 2013-10-29T13:52:48.637 回答
1

如果您坚持使用简单的正则表达式:

第一个已经回答了。第二个可以类似地写成:

a.replace(/[^#](?![^#]*#)/g, '*')
  • (?![^#]*#)是一个负前瞻,检查当前字符后没有磅。
  • [^#]还检查当前字符不是磅。(我们也可以使用/(?![^#]*#)./g,但它不那么漂亮。

一个积极的选择是:

a.replace(/[^#](?=[^#]*$)/g, '*');
  • 这与第一个非常相似:(?=[^#]*$)检查我们前面是否只有非磅,直到字符串的末尾。

在这两个选项中,字符串中没有磅的所有字符都将被替换:"abcd"->"****"

于 2013-10-29T14:56:08.467 回答