• Stars
    star
    625
  • Rank 71,862 (Top 2 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created almost 13 years ago
  • Updated 6 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Json2html is a lightning fast client side javascript HTML templating library with wrappers for both jQuery and Node.js.

json2html

json2html is an open source javascript library that uses js templates to render JSON objects into HTML.

Build lightning fast, interactive client side templates using nothing but javascript.

Free to use under the MIT license.

www.json2html.com for full documentation.

Features

  • Native JS templates that work both the client and server
  • Interactive with embedded events directly in your templates
  • 100% Javascript so no need to learn any new syntax: use inline js functions for complex logic

Example

json2html.render(
    [
        {"name": "Justice League", "year":2021},
        {"name": "Coming 2 America", "year":2021}
    ], 
    {"<>": "li", "html":[
    	{"<>": "span", "text": "${name} (${year})"}
      ]});
    

Will render the following html

<li>
	<span>Justice League (2021)</span>
</li>
<li>
	<span>Coming 2 America (2021)</span>
</li

jQuery

Use seemlessly with jQuery, oh did we also mention that you can embed events in your template? Forget attaching your events after you've rendered your templates.

 {"<>":"button","text":"Click Me","onclick":(e)=>{
	alert("You just clicked this");
  }};		

Will render into the following html and will alert when clicked :)

<button>Click Me</button>

Node.js

Use your temlpates seemlessly on Node.js

Installation

npm install node-json2html

Usage

	const json2html = require('node-json2html');
        
	let html = json2html.transform([{'male':'Bob','female':'Jane'},{'male':'Rick','female':'Ann'}],{"<>":"div","html":"${male} likes ${female}"});

TypeScript:

  import json2html from 'node-json2html'; //Import module
  const { render, component } = json2html; // Import methods from Json2html

www.json2html.com for full documentation.