| # babel-plugin-syntax-trailing-function-commas | 
|   | 
| Compile trailing function commas to ES5 | 
|   | 
|   | 
| ```js | 
| function clownPuppiesEverywhere( | 
|   param1, | 
|   param2, | 
| ) { /* ... */ } | 
|   | 
| clownPuppiesEverywhere( | 
|   'foo', | 
|   'bar', | 
| ); | 
| ``` | 
| [Try in REPL](http://babeljs.io/repl/#?evaluate=true&presets=es2015%2Cstage-0&code=function%20clownPuppiesEverywhere(%0A%20%20param1%2C%0A%20%20param2%2C%0A)%20%7B%20%2F*%20...%20*%2F%20%7D%0A%0AclownPuppiesEverywhere(%0A%20%20'foo'%2C%0A%20%20'bar'%2C%0A)%3B) | 
|   | 
| ## Example | 
|   | 
| ### Basic | 
| This is an example from the [Proposal](https://github.com/jeffmo/es-trailing-function-commas). | 
|   | 
| Let's say you have this function: | 
|   | 
| ```js | 
| function clownPuppiesEverywhere( | 
|   param1, | 
|   param2 | 
| ) { /* ... */ } | 
|   | 
| clownPuppiesEverywhere( | 
|   'foo', | 
|   'bar' | 
| ); | 
| ``` | 
|   | 
| If you want to have a new parameter called `param3`, the diff output would be like that: | 
|   | 
| ```diff | 
| function clownPuppiesEverywhere( | 
|   param1, | 
| - param2 | 
| + param2, // Change this line to add a comma | 
| + param3  // Add param3 | 
| ) { /* ... */ } | 
|   | 
| clownPuppiesEverywhere( | 
|   'foo', | 
| - 'bar' | 
| + 'bar', // Change this line to add a comma | 
| + 'baz'  // Add param3 | 
| ); | 
| ``` | 
| In total, you have to change 2 lines for the function declaration and 2 lines for each usage. | 
|   | 
| If you had your function defined with trailing commas: | 
|   | 
| ```js | 
| function clownPuppiesEverywhere( | 
|   param1, | 
|   param2, | 
| ) { /* ... */ } | 
|   | 
| clownPuppiesEverywhere( | 
|   'foo', | 
|   'bar', | 
| ); | 
| ``` | 
| Adding a new parameter would only change one line in the function declaration and one line for each usage: | 
|   | 
| ```diff | 
| function clownPuppiesEverywhere( | 
|   param1, | 
|   param2, | 
| + param3, // Add param3 | 
| ) { /* ... */ } | 
|   | 
| clownPuppiesEverywhere( | 
|   'foo', | 
|   'bar', | 
| + 'baz', // Add param3 | 
| ); | 
| ``` | 
| In the end, your diff output will be cleaner and easier to read, it would be much quicker to add a new parameter to your functions, it also makes it easier to copy paste elements and move code around. | 
|   | 
| ## Installation | 
|   | 
| ```sh | 
| npm install --save-dev babel-plugin-syntax-trailing-function-commas | 
| ``` | 
|   | 
| ## Usage | 
|   | 
| ### Via `.babelrc` (Recommended) | 
|   | 
| **.babelrc** | 
|   | 
| ```json | 
| { | 
|   "plugins": ["syntax-trailing-function-commas"] | 
| } | 
| ``` | 
|   | 
| ### Via CLI | 
|   | 
| ```sh | 
| babel --plugins syntax-trailing-function-commas script.js | 
| ``` | 
|   | 
| ### Via Node API | 
|   | 
| ```javascript | 
| require("babel-core").transform("code", { | 
|   plugins: ["syntax-trailing-function-commas"] | 
| }); | 
| ``` | 
|   | 
| ## References | 
|   | 
| * [Proposal](https://github.com/jeffmo/es-trailing-function-commas) | 
| * [Spec](http://jeffmo.github.io/es-trailing-function-commas/) | 
| * [Why you should enforce Dangling Commas for Multiline Statements](https://medium.com/@nikgraf/why-you-should-enforce-dangling-commas-for-multiline-statements-d034c98e36f8) |