在 2 个符号的索引处查找并拆分字符串

Find and split string at index of 2 symbols

本文关键字:查找 拆分 字符串 索引 符号      更新时间:2023-09-26

我正在做一些本地化编码,我正在尝试分离可能的替代方案。例如,我想从"en-US"或"en_US"中获取"en"。我已经为第一个选项制定了如何做到这一点,但我正在寻找最干净的方法来为连字符和下划线做到这一点。我首先想检查它是否可以拆分,这样我就不会在主要和备用区域设置中都使用"en"和"en"。

if (currLoc && currLoc.indexOf('-') > -1) {
    altLoc = currLoc.substring(0, currLoc.indexOf('-'));
}
如果您希望

字符串不是任意的,而只是en-USen_US或空或en。试试这段代码。

if(curLoc) {
    altLoc = currLoc.replace('-', '_').split('_')[0];
}

实际上,如果currLoc是空字符串,则可以省略if(curLoc)条件,在这种情况下,您的altLoc也将是空字符串。

怎么样

if ( currLoc ){
  if( currLoc.indexOf('-') > -1) 
    altLoc = currLoc.substring(0, currLoc.indexOf( '-' ));
  else if( currLoc.indexOf('_') > -1 )
    altLoc = currLoc.substring(0, currLoc.indexOf( '_' ));
}
var matches = new RegExp(/(.{2}).[-_](.{2})/gi).exec("fdgf-fed");
if (matches != null)
    altLoc  = matches[1];
var str = 'en_US';
var str1 = 'en-US';
var arr = str.replace(/[_-]/g, " ").split(" ");
arr[0] //en
arr[1] //US
var arr1 = str1.replace(/[_-]/g, " ").split(" ");
arr1[0] //en
arr1[1] //US

对于正则表达式方法,您可以使用:

var reg = new RegExp(/^([a-z]{2})[^0-9]|[^a-z]|[^A-Z].+/g);
var result = reg.exec(text);
//result[1] <-- first group: "en" in case of "en_Us,en_US,en-US..."