• micro-template改造


    (function ($) {
        $.fn.razor = function (data) {
            var render=$(this).data('razor');
            if (!render) {
                var html = $(this).html();
                var isNewEngine = ''.trim;
                if (isNewEngine) {
                    render = new Function("data",
                  "var p='';" +
                  "p+='" +
                  html.replace(/[
    	
    ]/g, " ").split("<%").join("	").replace(/((^|%>)[^	]*)'/g, "$1
    ").replace(/	=(.*?)%>/g, "';p+=$1;p+='").split("	").join("';").split("%>").join("p+='").split("
    ").join("\'") + "';return p;");
                }
                else {
                    render = new Function("data",
                     "var p=[];" +
                     "p.push('" +
                     html.replace(/[
    	
    ]/g, " ").split("<%").join("	").replace(/((^|%>)[^	]*)'/g, "$1
    ").replace(/	=(.*?)%>/g, "',$1,'").split("	").join("');").split("%>").join("p.push('").split("
    ").join("\'") + "');return p.join('');");
                }
                $(this).data('razor', render); 
            }
            return render(data);
        }
    })(jQuery);

    demo:

    <!DOCTYPE html>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>Razor模板引擎</title>
        <script src="Scripts/StringExtension.js"></script>
        <script src="Scripts/jquery-1.10.2.min.js"></script>
        <script src="Scripts/micro-template.js"></script>
        <script id="tmpl1" type="text/template">
            <ul>
                <%
                for(var i=0,j=data.length;i<j;i++){
                    var item=data[i];%>
                <li><%=item.Name%></li>
                <%}%>
            </ul>
        </script>
        <script id="tmpl2" type="text/template">
            <table>
                <%
                for(var i=0,j=data.length;i<j;i++){ 
                    var item=data[i];%>
                    <tr><td><%=item.Name%></td></tr>
                    <%}%>
            </table>
        </script>
        <script type="text/javascript">
            $(function () {
                var p = [];
                $('#tmpl1').razor(p);
                $('#tmpl2').razor(p);
                for (var i = 0; i < 10000; i++) {
                    p.push({Name:'xyz'+i.toString().padLeft('0',4)});
                }
    
                console.time('render1');
                $('#content1').html($('#tmpl1').razor(p));
                console.timeEnd('render1');
    
                console.time('render2');
                $('#content2').html($('#tmpl2').razor(p));
                console.timeEnd('render2');
            });       
        </script>
    </head>
    <body>  
        <div id="content1"></div>
        <div id="content2"></div>
    </body>
    </html>
  • 相关阅读:
    快速开发一个自己的微信小程序
    ES6系列汇总
    数组、Set对象的互相转换
    CORS 跨域
    模板引擎之hogan.js
    Flex 布局语法教程
    ES6 Javascript 实用开发技巧
    几种知名开源富文本编辑器对比
    python 字符串的一些操作
    python os模块一些常用操作
  • 原文地址:https://www.cnblogs.com/kingge/p/4857687.html
Copyright © 2020-2023  润新知