1.0.0 ā€¢ Published 5 years ago

mrjt v1.0.0

Weekly downloads
2
License
MIT
Repository
github
Last release
5 years ago

Mr. Jt šŸŽ©

Meet beardless customizable template engine, Mr. Jt for Node.js and Web browsers.

Build status release-src npm License

Build history

jt.use('', ' $Hello %p% {{world}} ')
    .as({ p: 'amazing'})
    .reset().as({ p: 'crazy'})
    // ... +$Hello, +{{world}}
jt.use('s1', 'Today is a {( a < b )} good {/} bad {;} day!')
    .sa(jtif, { a: 5, b: 7})
    .value()

Why Jt ?

Extremely small, fast, and damn customizable. Okay, Let's see what's going on:

Speed šŸš€

Only native lower-level implementation. Even for conditional statements, like:

{( d > 5 )} yes {/} no {;}

Which do not uses regex, or eval(), or new Function(), ... Feel the speed.

Size šŸ“¦

Extra small size. Just about o-n-e kilobyte of fully workable core engine:

  • ~ 1.02 KB for Core of ES6 gzipped;
  • ~ 1.09 KB for Core of ES3 gzipped;

Same things for custom handlers.

Configurable šŸ”§

You can configure, add, or change anything!

Jt was designed to be loyal to your preferences on the fly. Maybe for this:

jt.use('s1', 'Good {{p}}, $p -p- !')
    .as({ p: 'Jt' })
    .as({ p: 'Mr.' }, {op: '$'})
    .as({ p: 'morning' }, '{{}}')
    .val(),

Or for this:

// {( true )} yes {/} no {;} -> {if( true )} yes {else} no {endif}
    
jt.use('legacy', '{if( true )} yes {else} no {endif}!')
.sa(new JtIfHandler([ '{}' ],
{
    if: 'if',
    else: 'else',
    fi: 'endif',
}))
.val() // yes !

Or for something more ...

Extensible via Pluginable handlers šŸ—ƒ

Sure! Add or change any features for the layers, still on the fly.

Do you need something special? No problem, just implement IJtHandler to cover your awesome things. It easy.

Comfy but strong šŸŒ‡

Changeable layers through common chain will make you happy.

You can control everything just in a few steps:

jt.use('hello', 'Hello you from $tip, dear $name.')
    .as({ tip: 'Jt', name: 'John' }); // Hello you from Jt, dear John.

// ...

jt.use('hello')
    .as(-1, true)
    .as({ name: 'Denis' }) // Hello you from Jt, dear Denis.
    .reset()
    .as({ tip: 'Moscow' })
    .eject((v) => t.is(v, 'Hello you from Moscow, dear $name.'))
    ...
    .as({ name: '{( r > 100 )}friend{/}visitor{;}' })
    .sa(jtif, { r: actual }) // // Hello you from Moscow, dear friend.
    ...
    .val();
šŸ§

Stability šŸ— 

Clean API and its tests will take care of your peace of mind.

Compatibility šŸ—ø

Nothing special, we just provide separate ES3+/ES6+ support in Node.js and Web browsers environment. Choose more suitable package for your case.

No dependencies to something šŸ‘

Developed from scratch without dependencies to something from our end-product.

Open and Free šŸ°

Open Source project; MIT License, Yes! Enjoy!

License

Licensed under the MIT License (MIT)

Copyright (c) 2019  Denis Kuzmin < entry.reg@gmail.com > GitHub/3F

[ ā˜• Donate ]

API

Download

Build & Tests

npm install
gulp build --conf debug

Available tests can be raised by command:

npm test

We're waiting for your awesome contributions!