javascript - 如果在数组中不匹配,则从字符串中删除字符串字符

标签 javascript

我正在尝试遍历一个数组,该数组包含我希望我的输入字符串与之进行比较的字符串。所以方法是我循环输入字符串以检查每个字符是否与数组中存在的元素之一匹配。如果不只是用''替换那个字符。注意:正则表达式确实不是一个选项。

这是我的 JavaScript 的样子

var input = 'this is A [{}].-_+~`:; *6^123@#$%&*()?{}|\ ';
input.toLowerCase(input)

var allowed = ['0','1','2','3','4','5','6','7','8','9','a','b','c','d', 'e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','s','à','â','ä','è','é','ê','ë','î','ï','ô','œ','ù','û','ü','ÿ','ç','À','Â','Ä','È','É','Ê','Ë','Î','Ï','Ô','Œ','Ù','Û','Ü','Ÿ','Ç', ' '] 

var cleanStr = '';
for(var i = 0; i < input.length; i++){
    for(var j = 0; j< allowed.length; j++){
    if(input[i] !== allowed[j]){
        cleanStr = input.replace(input[i], ' ');
      console.log(cleanStr);
    }
  }
}

控制台日志输出似乎与输入字段没有任何不同。我错过了什么?

这是我的 fiddle

https://jsfiddle.net/sghoush1/nvnk7r9j/4/

最佳答案

您可以在一个循环中执行此操作。

var input = 'this is A [{}].-_+~`:; *6^123@#$%&*()?{}|\ ';
input = input.toLowerCase(); // Note the syntax here

var allowed = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'à', 'â', 'ä', 'è', 'é', 'ê', 'ë', 'î', 'ï', 'ô', 'œ', 'ù', 'û', 'ü', 'ÿ', 'ç', 'À', 'Â', 'Ä', 'È', 'É', 'Ê', 'Ë', 'Î', 'Ï', 'Ô', 'Œ', 'Ù', 'Û', 'Ü', 'Ÿ', 'Ç', ' '];

var cleanStr = '';

// Loop over each character in the string
for (var i = 0; i<input.length; i++) {

    // Check if the character is allowed or not
    if (allowed.indexOf(input[i]) !== -1) {
        // Concat the allowed character to result string
        cleanStr += input[i];
    }
}

console.log(cleanStr);
document.body.innerHTML = cleanStr;


正则表达式方法:

您可以使用 RegExp 从字符串创建正则表达式构造函数。要替换不允许的字符,negated character class可以使用正则表达式。

var regex = new RegExp('[^' + allowed.join('') + ']', 'g');
var cleanStr = input.replace(regex, '');

注意:您需要转义在 Character 类中具有特殊含义的元字符。

需要通过在 character class 中前面的反斜杠 \ 转义的元字符引自 www.regular-expressions.info

In most regex flavors, the only special characters or metacharacters inside a character class are the closing bracket (]), the backslash (\), the caret (^), and the hyphen (-).

var input = 'this is A [{}].-_+~`:; *6^123@#$%&*()?{}|\ ';
var allowed = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 's', 'à', 'â', 'ä', 'è', 'é', 'ê', 'ë', 'î', 'ï', 'ô', 'œ', 'ù', 'û', 'ü', 'ÿ', 'ç', 'À', 'Â', 'Ä', 'È', 'É', 'Ê', 'Ë', 'Î', 'Ï', 'Ô', 'Œ', 'Ù', 'Û', 'Ü', 'Ÿ', 'Ç', ' '];

var regex = new RegExp('[^' + allowed.join('') + ']', 'gi');
console.log(regex);

var cleanStr = input.replace(regex, '');
console.log(cleanStr);

如果允许的字符数组是固定的,你可以使用下面的正则表达式来替换不允许的字符。此外,无需将字符串转换为小写,使用 i 标志进行不区分大小写的匹配。

var regex = /[^0-9a-zàâäèéêëîïôœùûüÿç ]/gi;

RegEx101 Live Demo

关于javascript - 如果在数组中不匹配,则从字符串中删除字符串字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35367450/

相关文章:

javascript - 如何构建操纵 DOM 的 Angular 因子/服务

javascript - &lt;script&gt; require ('renderer.js' ) &lt;/script&gt; - 不连接js文件

javascript - 将谷歌地图事件监听器添加到 InfoWindows 中的自定义关闭按钮

javascript - AngularJS - 在整个应用程序中访问 promise 数据

Javascript 无法识别 SWT BrowserFunction

javascript - 按 Javascript 数组中的出现次数(计数)排序

javascript - 使 div 内容(googlemap)全屏显示

javascript - 如何使用JQuery获取xml中指定标签的直接子标签

javascript - jQuery 序列化问题

javascript - jQuery 在 for 循环中动态增加变量名