zoukankan      html  css  js  c++  java
  • JavaScript模板引擎使用

    1. [代码]tmpl.js     
    // Simple JavaScript Templating
    // John Resig - http://ejohn.org/ - MIT Licensed
    (function() {
    var cache = {};


    this.tmpl = function tmpl(str, data) {

    // Figure out if we're getting a template, or if we need to
    // load the template - and be sure to cache the result.
    var fn = 
    !/W/.test(str) 

    cache[str] = cache[str] || tmpl(document.getElementById(str).innerHTML) 
    :
    // Generate a reusable function that will serve as a template
    // generator (and which will be cached).
    new Function(
    "obj", "var p=[],print=function(){p.push.apply(p,arguments);};" +

    // Introduce the data as local variables using with(){}
    "with(obj){p.push('" +

    // Convert the template into pure JavaScript
    strhttp://www.huiyi8.com/jiaoben/
    .replace(/[ ]/g, " ")
    .split("<%").join(" ")
    .replace(/((^|%>)[^ ]*)'/g, "$1 ")
    .replace(/ =(.*?)%>/g, "',$1,'")
    .split(" ")
    .join("');")
    .split("%>")
    .join("p.push('")
    .split(" ")
    .join("\'") + 
    "');}return p.join('');"
    ); // Function ends


    // Provide some basic currying to the user
    return data ? fn(data) : fn;
    };
    })(); 
    2. [脚本代码]index.html     
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
    "http://www.w3.org/TR/html4/loose.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>jQuery特效
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>JavaScript tmpl Use Demo</title>
    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
    <script src="./tmpl.js" type="text/javascript"></script>
                    <!-- 下面是模板user_tmpl -->
    <script type="text/html" id="user_tmpl">
    <% for ( var i = 0; i < users.length; i++ ) { %>
    <li><a href="<%=users[i].url%>"><%=users[i].name%></a></li>
    <% } %>
    </script>
    <script type="text/javascript">
                            // 用来填充模板的数据
    var users = [
    { url: "http://baidu.com", name: "jxq"},
    { url: "http://google.com", name: "william"}
    ];

    $(function() {
                                   // 调用模板引擎函数将数据填充到模板获得最终内容
    $("#myUl").html(tmpl("user_tmpl", users));
    });
    </script>
    </head>
    <body>
    <div>
    <ul id="myUl">
    </ul>
    </div>
    </body>
    </html>

  • 相关阅读:
    HDU1260DP
    HDU1114 背包
    HDU1078记忆化搜索
    HDU1024 最大m子段和
    Codeforces Round #401 (Div. 2) A,B,C,D,E
    HDU3666 差分约束
    HDU1540 区间合并
    HDU3308 线段树(区间合并)
    Codeforces Round #403 (Div. 2) B 三分 C dfs
    HDU1573 线性同余方程(解的个数)
  • 原文地址:https://www.cnblogs.com/xkzy/p/3822525.html
Copyright © 2011-2022 走看看