@starptech/expression-parser

0.10.0 • Public • Published

@starptech/expression-parser

Framework agnostic template expression parser

Installation

npm install --save @starptech/expression-parser

Usage

This example shows how we parse HTML

const parse = require('@starptech/expression-parser')
const result = parse(`{ a + /<g></g> b }`, { brackets: ['{', '}'] })

Representation

  • unescape: Indentify a template marker as escaped. This information is useful to understand why a marker was skipped
  • expressions: A list of template expressions
    • start: Start position
    • end: End position
    • text: The content of the expression
{
  "unescape": "",
  "expressions": [
    {
      "start": 1,
      "end": 19,
      "text": " a + /<g></g> b "
    }
  ]
}

Details

There may be more than one expression as part of one attribute value or text node, or only one replacing the entire value or node.

When used as the whole attribute value, there's no need to enclose the expression inside quotes, even if the expression contains whitespace.

Single and double quotes can be nested inside the expression.

To emit opening (left) brackets as literal text wherever an opening bracket is expected, the bracket must be prefixed with a backslash (the JS escape char ''). This character is preserved in the output, but the parser will add a replace property for the attribute or node containing the escaped bracket, whose value is the bracket itself.

Credits

The parser is a modificated version of Riot template expression parser.

Package Sidebar

Install

npm i @starptech/expression-parser

Weekly Downloads

3,835

Version

0.10.0

License

MIT

Unpacked Size

14.7 kB

Total Files

4

Last publish

Collaborators

  • starptech