最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

How do templating engines in JavaScript work? - Stack Overflow

programmeradmin0浏览0评论

Could you please explain me, how do templating engines in JavaScript work? Thank you.

JSON

{ "color" : "red"}

Template

<strong><%=color%></strong>

Result

<strong>Red</strong>

Could you please explain me, how do templating engines in JavaScript work? Thank you.

JSON

{ "color" : "red"}

Template

<strong><%=color%></strong>

Result

<strong>Red</strong>
Share Improve this question asked Apr 19, 2010 at 18:15 Randy GurmentRandy Gurment 1772 silver badges6 bronze badges 2
  • Your question is not very clear. Can you provide more context? – Vivin Paliath Commented Apr 19, 2010 at 18:17
  • 2 I think that in general the approach for making a template engine is to select the appropriate algorithms and implement them using best-practice techniques to achieve the desired result. – Pointy Commented Apr 19, 2010 at 18:19
Add a ment  | 

3 Answers 3

Reset to default 9

As a starting point I would remend you to give a look to the String.prototype.replace method and specially using its callback function:

function replaceTokens(str, replacement) {
  return str.replace(/<\%=([^%>]+)\%>/g, function (str, match) {
    return replacement[match];
  });
}

var input = "<strong><%=color%></strong>";
replaceTokens(input, { "color" : "Red"}); 
// returns <strong>Red</strong>

replaceTokens("<%=var1%> <%=var2%>", { "var1" : "Hello", "var2": "world!"});
// returns "Hello world!"

Give a look to these articles:

  • Search and Don't Replace
  • John Resig's Micro-Templating Engine
  • Better JavaScript Templates (JSP-like syntax)
  • jQuery Templates Proposal

They may vary by implementation, but the one you're talking about looks like it works by doing the following:

  1. Parse the page looking for keys in <%= %> tags

  2. Match the key to the key/value pair in the JSON

  3. Replace the tags/key with the value.

It's not very different from other templating solutions (at the conceptual level).

{ "color" : "red"}

Specifies a color attribute with the value red.

<strong><%=color%></strong>

Means "Use the value of color wherever I have <%=color%>. Based on wahat you have, the templating-engine probably walks the DOM and finds nodes that have values that match <%=somestring%>. Then, it checks to see if there is an attribute that matches the somestring value. If there is one, it replaces the value of <%=somestring%> with the value defined in the JSON (which, in this case is red).

This finally gives you:

<strong>Red</strong>
发布评论

评论列表(0)

  1. 暂无评论