An open API service indexing awesome lists of open source software.

https://github.com/pgilad/unquoted-property-validator

Unquoted JavaScript property name validator
https://github.com/pgilad/unquoted-property-validator

identifier javascript literal quotes validation

Last synced: about 1 year ago
JSON representation

Unquoted JavaScript property name validator

Awesome Lists containing this project

README

          

# unquoted-property-validator
> Unquoted JavaScript property name validator

[![NPM Version](http://img.shields.io/npm/v/unquoted-property-validator.svg?style=flat)](https://npmjs.org/package/unquoted-property-validator)
[![NPM Downloads](http://img.shields.io/npm/dm/unquoted-property-validator.svg?style=flat)](https://npmjs.org/package/unquoted-property-validator)
[![Build Status](http://img.shields.io/travis/pgilad/unquoted-property-validator.svg?style=flat)](https://travis-ci.org/pgilad/unquoted-property-validator)

This module checks if a given property name can be used without quotes and/or with dot notation.

It is based on Mathias Bynens brilliant [javascript-properties article](https://mathiasbynens.be/notes/javascript-properties).
So this is a **node-port** of his [website implementation](https://github.com/mathiasbynens/mothereff.in/tree/master/js-properties).

## Installation

```bash
$ npm install unquoted-property-validator --save
```

## Usage

```js
var unquotedValidator = require('unquoted-property-validator');

var results = unquotedValidator('myCoolLiteral');
console.log(results);
/* {
needsQuotes: false,
needsBrackets: false,
es3Warning: false,
quotedValue: 'myCoolLiteral'
}
*/
```

In ES6/Typescript the first line should look like this instead:

```js
import unquotedValidator = require('unquoted-property-validator');
```

## Results

Your property input will be checked and you will get 3 flags as output:

### needsQuotes

Quotes can only be omitted if the property name is a numeric literal or a valid identifier name:

```js
var obj = {
nonQuoted: true,
'must-be-quoted' : true
};
```

### needsBrackets

Dot notation can only be used when the property name is a valid identifier name:

```js
obj.bracketFree = true; //use the supreme dot notation
obj['requires-brackets'] = true; //string must be inside brackets to be used as property
```

### es3Warning

Should you want to support ES3, you cannot use some identifiers:
```js
obj['var'] //-> invalid in ES3
var obj = {
goto: true //-> invalid in ES3
};
```

### quotedValue

Your quoted string in case there are problematic characters.

## API

`unquotedValidator(input)`

### input

Type: `String`

Property to validate

## License

MIT © [Gilad Peleg](https://www.giladpeleg.com)