Javascript 将 PascalCase 转换为 underscore_case/snake_case



如何将PascalCase字符串转换为underscore_case/snake_case字符串?我也需要将点转换为下划线。

例如,转换

TypeOfData.AlphaBeta

type_of_data_alpha_beta

您可以尝试以下步骤。

  • 捕获所有大写字母,并匹配前面的可选点字符。

  • 然后将捕获的大写字母转换为小写字母,然后返回以替换功能,并用_作为前置字符。这将通过在更换部件中使用匿名功能来实现。

  • 这会将开头的大写字母替换为 _ + lowercase_letter。

  • 最后,删除起始下划线将为您提供所需的输出。

    var s = 'TypeOfData.AlphaBeta';
    console.log(s.replace(/(?:^|.?)([A-Z])/g, function (x,y){return "_" + y.toLowerCase()}).replace(/^_/, ""));
    

var s = 'TypeOfData.AlphaBeta';
alert(s.replace(/.?([A-Z])/g, function (x,y){return "_" + y.toLowerCase()}).replace(/^_/, ""));

当整个单词为大写时停止它的任何方法。 例如。 MotorRPM进入motor_rpm而不是motor_r_p_m?还是BatteryAAA battery_aaa而不是battery_a_a_a

var s = 'MotorRMP';
alert(s.replace(/.?([A-Z]+)/g, function (x,y){return "_" + y.toLowerCase()}).replace(/^_/, ""));

str.split(/.?(?=[A-Z])/).join('_').toLowerCase();

不客气

var s1 = 'someTextHere';
var s2 = 'SomeTextHere';
var s3 = 'TypeOfData.AlphaBeta';
var o1 = s1.split(/.?(?=[A-Z])/).join('_').toLowerCase();
var o2 = s2.split(/.?(?=[A-Z])/).join('_').toLowerCase();
var o3 = s3.split(/.?(?=[A-Z])/).join('_').toLowerCase();
console.log(o1);
console.log(o2);
console.log(o3);

或者使用 lodash:

lodash.snakeCase(str);

例:

_.snakeCase('TypeOfData.AlphaBeta');
// ➜ 'type_of_data_alpha_beta'

Lodash 是一个很好的库,可以为许多日常 js 任务提供快捷方式。还有许多其他类似的字符串操作函数,如camelCasekebabCase等。

此解决方案解决了上述解决方案的非尾随首字母缩略词问题

我将1175208中的代码从 Python 移植到 JavaScript。

Javascript Code

function camelToSnakeCase(text) {
    return text.replace(/(.)([A-Z][a-z]+)/, '$1_$2').replace(/([a-z0-9])([A-Z])/, '$1_$2').toLowerCase()
}

工作实例:

camelToSnakeCase('thisISDifficult') -> this_is_difficult
camelToSnakeCase('thisISNT') -> this_isnt
camelToSnakeCase('somethingEasyLikeThis') -> something_easy_like_this
"alphaBetaGama".replace(/([A-Z])/g, "_$1").toLowerCase() // alpha_beta_gamma

问题 - 需要将驼峰大小写字符串(如属性名称(转换为下划线样式以满足接口要求或用于元编程。

解释此行使用正则表达式的特性,它可以返回匹配的结果(第一对((是$1,第二对是$2,等等(。

字符串中的每个匹配项都转换为在其前面有一个下划线,并提供_$1字符串。此时,字符串看起来像alpha_Beta_Gamma .

为了更正大小写,整个字符串将转换为 LowerCase((。

由于 toLowerCase 是一个相当昂贵的操作,因此最好不要将其放在每个匹配案例的循环处理程序中,并在整个字符串上运行一次。

toLowerCase后,生成的字符串alpha_beta_gamma(在本例中(

这会让你走得更远: https://github.com/domchristie/humps

您可能必须使用正则表达式替换将"."替换为下划线。

我找到了这个,但我编辑了它,所以适合你的问题。

const camelToSnakeCase = str => str.replace(/[A-Z]/g, letter => `_${letter.toLowerCase()}`).replace(/^_/,'')

js 的好例子:

  1. 蛇案
  2. 烤肉串案例
  3. 骆驼案例
  4. 帕斯卡案例

这里有

function toCamelCase(s) {
  // remove all characters that should not be in a variable name
  // as well underscores an numbers from the beginning of the string
  s = s.replace(/([^a-zA-Z0-9_- ])|^[_0-9]+/g, "").trim().toLowerCase();
  // uppercase letters preceeded by a hyphen or a space
  s = s.replace(/([ -]+)([a-zA-Z0-9])/g, function(a,b,c) {
    return c.toUpperCase();
  });
  // uppercase letters following numbers
  s = s.replace(/([0-9]+)([a-zA-Z])/g, function(a,b,c) {
    return b + c.toUpperCase();
  });
  return s;
}

试试这个功能,希望对你有帮助。

"TestString".replace(/[A-Z]/g, val => "_" + val.toLowerCase()).replace(/^_/,"")

将所有大写字母替换为下划线和小写字母,然后删除前导下划线。

将PascalCase转换为snake_case的非正则表达式答案

注意:我知道有很多很好的答案可以优雅地解决这个问题。我最近正在研究与此类似的东西,我选择不使用regex。所以我觉得要回答一个non-regex的解决方案。

const toSnakeCase = (str) => {
    return str.slice(0,1).toLowerCase() + str.split('').slice(1).map((char) => {
        if (char == char.toUpperCase()) return '_' + char.toLowerCase();
        else return char;
    }).join('');
}

例如。

inputString = "ILoveJavascript" passed onto toSnakeCase()

会变得"i_love_javascript"

最新更新