在 2 个符号的索引处查找并拆分字符串
Find and split string at index of 2 symbols
我正在做一些本地化编码,我正在尝试分离可能的替代方案。例如,我想从 'en-US' 或 'en_US' 得到 'en'。我已经为第一个选项制定了如何执行此操作,但我正在寻找最干净的方法来为连字符和下划线执行此操作。我首先想检查它是否可以拆分,这样我就不会在主要和备用语言环境中得到 'en' 和 'en'。
if (currLoc && currLoc.indexOf('-') > -1) {
altLoc = currLoc.substring(0, currLoc.indexOf('-'));
}
怎么样
if ( currLoc ){
if( currLoc.indexOf('-') > -1)
altLoc = currLoc.substring(0, currLoc.indexOf( '-' ));
else if( currLoc.indexOf('_') > -1 )
altLoc = currLoc.substring(0, currLoc.indexOf( '_' ));
}
如果您希望字符串不是任意的,而只是 en-US
或 en_US
或空或 en
。试试这个代码。
if(curLoc) {
altLoc = currLoc.replace('-', '_').split('_')[0];
}
实际上,如果 currLoc
是空字符串,则可以省略 if(curLoc)
条件,在这种情况下,您的 altLoc
也将是空字符串。
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..."
我正在做一些本地化编码,我正在尝试分离可能的替代方案。例如,我想从 'en-US' 或 'en_US' 得到 'en'。我已经为第一个选项制定了如何执行此操作,但我正在寻找最干净的方法来为连字符和下划线执行此操作。我首先想检查它是否可以拆分,这样我就不会在主要和备用语言环境中得到 'en' 和 'en'。
if (currLoc && currLoc.indexOf('-') > -1) {
altLoc = currLoc.substring(0, currLoc.indexOf('-'));
}
怎么样
if ( currLoc ){
if( currLoc.indexOf('-') > -1)
altLoc = currLoc.substring(0, currLoc.indexOf( '-' ));
else if( currLoc.indexOf('_') > -1 )
altLoc = currLoc.substring(0, currLoc.indexOf( '_' ));
}
如果您希望字符串不是任意的,而只是 en-US
或 en_US
或空或 en
。试试这个代码。
if(curLoc) {
altLoc = currLoc.replace('-', '_').split('_')[0];
}
实际上,如果 currLoc
是空字符串,则可以省略 if(curLoc)
条件,在这种情况下,您的 altLoc
也将是空字符串。
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..."