Хабр Курсы для всех
РЕКЛАМА
Практикум, Хекслет, SkyPro, авторские курсы — собрали всех и попросили скидки. Осталось выбрать!
<% if (some.variable) { %>new Date().toString()Любому начинающему кодеру известно, что PHP позволяет обрабатывать html и php код вперемешку в одном файле. Опытным же кодерам известно, что это быдлокод.
var data = {
products : [ { name: "mac", desc: "computer",
price: 1000, quantity: 100, alert:null },
{ name: "ipod", desc: "music player",
price: 200, quantity: 200, alert:"on sale now!" },
{ name: "cinema display", desc: "screen",
price: 800, quantity: 300, alert:"best deal!" } ],
customer : { first: "John", last: "Public", level: "gold" }
};
var result = myTemplateStr.process(data);
someOutputDiv.innerHTML = result;
Hello ${customer.first} ${customer.last}.<br/>
Your shopping cart has ${products.length} item(s):
<table>
<tr><td>Name</td><td>Description</td>
<td>Price</td><td>Quantity & Alert</td></tr>
{for p in products}
<tr><td>${p.name|capitalize}</td><td>${p.desc}</td>
<td>$${p.price}</td><td>${p.quantity} : ${p.alert|default:""|capitalize}</td>
</tr>
{forelse}
<tr><td colspan="4">No products in your cart.</tr>
{/for}
</table>
{if customer.level == "gold"}
We love you! Please check out our Gold Customer specials!
{else}
Become a Gold Customer by buying more stuff here.
{/if}
Hello John Public.<br/>
Your shopping cart has 3 item(s):
<table>
<tr><td>Name</td><td>Description</td>
<td>Price</td><td>Quantity & Alert</td></tr>
<tr><td>MAC</td><td>computer</td>
<td>$1000</td><td>100 : </td>
</tr>
<tr><td>IPOD</td><td>music player</td>
<td>$200</td><td>200 : ON SALE NOW!</td>
</tr>
<tr><td>CINEMA DISPLAY</td><td>screen</td>
<td>$800</td><td>300 : BEST DEAL!</td>
</tr>
</table>
We love you! Please check out our Gold Customer specials!
<html>
<head><title><%- title %></title></head>
<body>
<%*%>
</body>
</html>
<%! layout %>
<div>
<h1><%- sectionTitle %></h1>
<div><%*%></div>
</div>
<%! sublayout %>
<h2><%- pageTitle %></h2>
<p><%- content %></p>
{ title: 'My Site', sectionTitle: 'My Section', pageTitle: 'My Page', content: 'My Content'}
<html>
<head><title>My Site</title></head>
<body>
<div>
<h1>My Section</h1>
<div>
<h2>My Page</h2>
<p>My Content</p>
</div>
</div>
</body>
</html>
Высокая скорость работы
html.slice(i, openLength + i)
// =>
html.substring(i, openLength)
html.substr(i, 1)
// вместо более быстрого
html.charAt(i)
while (~(n = js.indexOf('\n', n))) n++, lineNo++;
// =>
lineNo += js.split('\n').length - 1;
.replace(/^\s\s*/, '').replace(/\s\s*$/, '')
// =>
.replace(/^\s+/, '').replace(/\s+$/, '')
// или если не заботят старые браузеры
.trim()
new Function([], buffer);
// =>
new Function(buffer);
blank.apply(that, []);
// =>
blank.call(that);
Object.prototype.toString.call(options.root).slice(8, -1) == 'Object'
Object.prototype.toString.call(data).slice(8, -1) == 'String'
// вместо
typeof options.root == 'object'
typeof data == 'string'
buffer[i] instanceof Array
// это не во всех браузерах будет работать
// в современных браузерах есть Array.isArray, для старых можно сделать эмуляцию, вот тут как раз нужен toString
if (typeof Array.isArray != 'function')
Array.isArray = function(value){
return Object.prototype.toString.call(value) === '[object Array]';
}
...
Array.isArray(buffer[i])
var rx = new RegExp(options.open + '((?:.|[\r\n])+?)(?:' + options.close + '|$)');
// тут надо позаботится чтобы в options.open/close не было управляющих символов
// или var rx = /<%((?:.|[\r\n])+?)(?:%>|$)/;
var matches = html.split(rx);
for (var i = 0, lineNo = 1, len = matches.length; i < len; i++)
{
var text = matches[i];
if (i & 1) // каждое нечетное вхождение это содержимое между options.open и options.close
{
var prefix, postfix, line = 'this.line=' + lineNo;
var jsFromPos = 1;
switch(text.charAt(0))
{
case '@':
prefix = '\', (' + line + ', this.partial(\'';
postfix = '\')), \'';
break;
//...
default:
prefix = '\');' + line + ';';
postfix = '; this.buffer.push(\'
jsFromPos = 0;
}
buffer.push(prefix, text.substr(jsFromPos).replace(/^\s+|\s+$/g, ''), text.postfix)
}
else // каждое четное текст между вставками
{
buffer.push(
text
.replace(/[\\']/g, '\\$&')
.replace(/\r/g, ' ')
.replace(/\n/g, '\\n')
);
}
lineNo += text.split(/\n/).length - 1;
}
...
catch(e){
// var rx = new RegExp(options.open + '((?:.|[\r\n])+?)(?:' + options.close + '|$)');
// rx у вас по идее должен один раз объявляться
var lineNo = html.split(rx)
.slice(0, this.partNo) // в partNo сохраняется i при разборе, вместо lineNo
.join('')
.split('\n')
.length - 1;
...
}
JUST — JavaScript шаблонизатор