Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/domchristie/humps
🐫 Underscore-to-camelCase converter (and vice versa) for strings and object keys in JavaScript.
https://github.com/domchristie/humps
Last synced: 29 days ago
JSON representation
🐫 Underscore-to-camelCase converter (and vice versa) for strings and object keys in JavaScript.
- Host: GitHub
- URL: https://github.com/domchristie/humps
- Owner: domchristie
- Archived: true
- Created: 2012-09-02T18:50:39.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-10-12T17:56:37.000Z (over 1 year ago)
- Last Synced: 2024-09-26T22:22:54.578Z (5 months ago)
- Language: JavaScript
- Homepage:
- Size: 78.1 KB
- Stars: 1,419
- Watchers: 8
- Forks: 99
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-nodejs - humps - Underscore-to-camelCase converter (and vice versa) for strings and object keys in JavaScript. ![](https://img.shields.io/github/stars/domchristie/humps.svg?style=social&label=Star) (Repository / Object / JSON / JSON Schema)
README
humps [![Build status](https://secure.travis-ci.org/domchristie/humps.png)](http://travis-ci.org/#!/domchristie/humps)
=====**This project is no longer maintained.**
Underscore-to-camelCase converter (and vice versa) for strings and object keys in JavaScript.
When converting object keys, it will walk the structure, converting any nested objects (or arrays of nested objects) along the way. Handy for converting JSON between JavaScript and Ruby/Rails APIs.
Takes inspiration from [Ember Data](https://github.com/emberjs/data) and copies some utility functions from [Underscore.js](http://underscorejs.org/).
Usage
-----### Converting strings
humps.camelize('hello_world') // 'helloWorld'
humps.decamelize('fooBar') // 'foo_bar'
humps.decamelize('fooBarBaz', { separator: '-' }) // 'foo-bar-baz'### Converting object keys
var object = { attr_one: 'foo', attr_two: 'bar' }
humps.camelizeKeys(object); // { attrOne: 'foo', attrTwo: 'bar' }Arrays of objects are also converted
var array = [{ attr_one: 'foo' }, { attr_one: 'bar' }]
humps.camelizeKeys(array); // [{ attrOne: 'foo' }, { attrOne: 'bar' }]It also accepts a callback which can modify the conversion behavior. For example to prevent conversion of keys containing only uppercase letters or numbers:
humps.camelizeKeys(obj, function (key, convert) {
return /^[A-Z0-9_]+$/.test(key) ? key : convert(key);
});
humps.decamelizeKeys(obj, function (key, convert, options) {
return /^[A-Z0-9_]+$/.test(key) ? key : convert(key, options);
});In order to use the callback with options use the `process` option:
humps.decamelizeKeys(obj, {
separator: '-',
process: function (key, convert, options) {
return /^[A-Z0-9_]+$/.test(key) ? key : convert(key, options);
}
});API
---### `humps.camelize(string)`
Removes any hypens, underscores, and whitespace characters, and uppercases the first character that follows.
```javascript
humps.camelize('hello_world-foo bar') // 'helloWorldFooBar'
```### `humps.pascalize(string)`
Similar to `humps.camelize(string)`, but also ensures that the first character is uppercase.
```javascript
humps.pascalize('hello_world-foo bar') // 'HelloWorldFooBar'
```### `humps.decamelize(string, options)`
Converts camelCased string to an underscore-separated string.
```javascript
humps.decamelize('helloWorldFooBar') // 'hello_world_foo_bar'
```The separator can be customized with the `separator` option.
```javascript
humps.decamelize('helloWorldFooBar', { separator: '-' }) // 'hello-world-foo-bar'
```By default, `decamelize` will only split words on capital letters (not numbers as in humps pre v1.0). To customize this behaviour, use the `split` option. This should be a regular expression which, when passed into `String.prototype.split`, produces an array of words (by default the regular expression is: `/(?=[A-Z])/`). For example, to treat numbers as uppercase:
```javascript
humps.decamelize('helloWorld1', { split: /(?=[A-Z0-9])/ }) // 'hello_world_1'
```### `humps.depascalize(string, options)`
Same as `humps.decamelize` above.
### `humps.camelizeKeys(object, options)`
Converts object keys to camelCase. It also converts arrays of objects.
### `humps.pascalizeKeys(object, options)`
Converts object keys to PascalCase. It also converts arrays of objects.
### `humps.decamelizeKeys(object, options)`
Separates camelCased object keys with an underscore. It also converts arrays of objects. See `humps.decamelize` for details of options.
### `humps.depascalizeKeys(object, options)`
See `humps.decamelizeKeys`.
Licence
-------
humps is copyright © 2012+ [Dom Christie](http://domchristie.co.uk) and released under the MIT license.