The Data.
var vdata = {
title : 'tipJSP template engine',
name : 'peku',
age : 20,
money : 1000000,
list : ['list1', 'list2', 'list3'],
obj : {a:'obj1', b:'obj2', c:'obj3'}
};
Below is quick example how to use tipJSP.js:
var vdata = {
name : "peku",
age : 20
};
var html = tipJSP.render("<ul><li><@=name@></li><li><@=age@></li></ul>", vdata);
// output "<ul><li>peku</li><li>20</li></ul>"
var vdata = {
title : 'tipJSP template engine',
name : 'peku',
age : 20,
money : 1000000,
list : ['list1', 'list2', 'list3'],
obj : {a:'obj1', b:'obj2', c:'obj3'}
};
npm install tipjsp -save
<script src='tipJSP.js'></script>
app.engine( 'jsp', require('tipjsp') );
app.set('views', __dirname + '/views');
app.set('view engine', 'jsp');
// or
app.engine( 'jsp', require('tipjsp').setSep('<%', '%>') );
...
<script type='text/tipJSP' id='template'>
<ul>
<@ for(var i=0; i<arr.length; i++){ @>
<li><@= arr[i] @></li>
<@ } @>
</ul>
</script>
var vdata = {
arr : ["peku1","peku2","peku3"]
};
var html = tipJSP.render(document.getElementById("template").innerHTML, vdata);
console.log(html);
<ul>
<li>peku1</li>
<li>peku2</li>
<li>peku3</li>
</ul>
var vdata = {
arr : ["peku1","peku2","peku3"]
};
var html = tipJSP.renderFile("./template.jsp", vdata);
console.log(html);
<ul>
<@# i in arr @>
<li><@= arr[i] @></li>
<@ } @>
</ul>
var vdata = {
arr : ["peku1","peku2","peku3"]
};
var html = tipJSP.render(templateStr, vdata);
<ul>
<li>peku1</li>
<li>peku2</li>
<li>peku3</li>
</ul>
<ul>
<@# k in obj @>
<li><@= obj[k] @></li>
<@ } @>
</ul>
var vdata = {
obj : {a:"peku1",b:"peku2",c:"peku3"}
};
var html = tipJSP.render(templateStr, vdata);
<ul>
<li>peku1</li>
<li>peku2</li>
<li>peku3</li>
</ul>
<@# input @> or <@# input == true @>
<h1><@= value1 @></h1>
<@ } @>
<@# !input @> or <@# input == false @>
<h1><@= value2 @></h1>
<@ } @>
var vdata = {
input : true,
value1 : 'true',
value2 : 'false'
};
var html = tipJSP.render(templateStr, vdata);
<h1>true</h1>
<html>
<body>
<h1>TITLE</h1>
<ul>
<@match child1@>
</ul>
<ul>
<@match child2@>
</ul>
</body>
</html>
<@extends base.jsp@>
<@match child1@>
<li>child1-1</li>
<li>child1-2</li>
<@match child2@>
<li>child2-1</li>
<li>child2-2</li>
var html = tipJSP.renderFile('index.jsp', vdata);
<html>
<body>
<h1>TITLE</h1>
<ul>
<li>child1-1</li>
<li>child1-2</li>
</ul>
<ul>
<li>child2-1</li>
<li>child2-2</li>
</ul>
</body>
</html>
<h1>HEADER</h1>
<html>
<body>
<@ include header.jsp @>
</body>
</html>
<html>
<body>
<h1>HEADER</h1>
</body>
</html>
var vdata = {
arr : ["peku1","peku2","peku3"]
};
var str = document.getElementById("template").innerHTML;
tipJSP.setCache(true); // enable/disable compile cache
var html = tipJSP.render(str, vdata);
// or
var html = tipJSP.setCache(true).render(str, vdata);
<ul>
<% for(var i=0; i<arr.length; i++){ %>
<li><%= arr[i] %></li>
<% } %>
</ul>
var vdata = {
arr : ["peku1","peku2","peku3"]
};
var str = document.getElementById("template").innerHTML;
tipJSP.setSep('<%', '%>');
var html = tipJSP.render(str, vdata);
// or
var html = tipJSP.setSep('<%', '%>').render(str, vdata);
console.log(html);
// input = 'peku1\r\npeku2\rpeku3';
<@= input|cr2,'\n' @>
// output = 'peku1\npeku2\npeku3';
// input = 'peku1\r\npeku2\npeku3';
<@= input|cr2br @>
// output = 'peku1<br />peku2<br />peku3';
// input = '가나다abc';
<@= input|cutStrb,2 @>
// output = '가나...';
<@= input|cutStrb,5,'..' @>
// output = '가나다ab..';
// input = 1388556061000; // milliseconds or dateString
<@= input|date,'yyyy/MM/dd HH:mm:ss' @>
// output = '2014/01/01 15:01:01';
<@= input|date,'yyyy년 MM月 ddDay hh:mm:ss:ap',['Morning', 'Noon'] @>
// output = '2014년 01月 01Day 03:01:01:Noon';
<@= input|date,'yy-MM-dd hh:mm:ss:ap' @>
// output = '14-01-01 03:01:01:PM';
// input = '<h1>abc</h1>&\'"';
<@= input|escapeHtml @>
// output = '<h1>abc</h1>&'"';
// input = 'a\\b\\c';
<@= input|escapeBackslash @>
// output = 'a\\\\b\\\\c';
// input = 1234567;
<@= input|numcomma @>
// output = '1,234,567';
<@= input|numcomma,'원' @>
// output = '1,234,567원';
// input = '<h1>abc</h1>&\'"';
<@= input|stripTag @>
// output = 'abc&\'"';
// input = ' abc d ef ';
<@= input|trim @>
// output = 'abc d ef';
<div><@= num|double @></div>
<div><@= num|half @></div>
var vdata = {
age : 20
};
var userModifier = {
double : function( num ){
return num * 2;
},
half : function( num ){
return num / 2;
}
};
var str = document.getElementById("template").innerHTML;
tipJSP.setModifier( userModifier );
var html = tipJSP.render(str, vdata);
// or
var html = tipJSP.setModifier( userModifier ).render(str, vdata);
console.log(html);
<div>40</div>
<div>10</div>