zoukankan      html  css  js  c++  java
  • javascript——浅谈javascript模版(自定义)

     1 /**
     2  * Created by Administrator on 15-1-19.
     3  */
     4 function functionUtil() {
     5 
     6 }
     7 
     8 functionUtil = {
     9     //某个DOM节点是否有某个属性
    10     hasAttr: function (el, name) {
    11         var attr = el.getAttributeNode && el.getAttributeNode(name);
    12         return attr ? attr.specified : false
    13     },
    14     //根据class获取元素
    15     getByClass: function (sClass, oParent) {
    16         oParent = oParent || document;
    17         if (!oParent.getElementsByClassName) {
    18             return oParent.getElementsByClassName(sClass);
    19         }
    20         var arr = [];
    21         var aEle = oParent.getElementsByTagName('*');
    22         var reg = new RegExp('(^|\s)' + sClass + '(\s|$)');
    23         //var reg = new RegExp('(^|[\x20\t\r\n\f])' + sClass + '([\x20\t\r\n\f]|$)');
    24         for (var i = 0; i < aEle.length; i++) {
    25             if (reg.test(aEle[i].className)) {
    26                 arr.push(aEle[i]);
    27             }
    28         }
    29         return arr;
    30     },
    31     //动态添加样式表
    32     addSheetFile: function (path) {
    33         var fileref = document.createElement("link")
    34         fileref.rel = "stylesheet";
    35         fileref.type = "text/css";
    36         fileref.href = path;
    37         fileref.media = "screen";
    38         var headobj = document.getElementsByTagName('head')[0];
    39         headobj.appendChild(fileref);
    40     },
    41     //根据指定格式如 ${name} 绑定json数据
    42     LoadJsonData: function (sParent, oJson) {
    43         var oParent = document.getElementById(sParent);
    44         if (oJson instanceof Array) {
    45             var str = oParent.innerHTML;
    46             for (var i = 0; i < oJson.length - 1; i++) {
    47                 oParent.innerHTML += str;
    48             }
    49             for (var d in oJson) {
    50                 oParent.children[d].innerHTML = oParent.children[d].innerHTML.replace(/${(w+)}/g, function (str, $1) {
    51                     return oJson[d][$1] ? oJson[d][$1] : '';
    52                 });
    53             }
    54 
    55         } else {
    56             oParent.innerHTML = oParent.innerHTML.replace(/${(w+)}/g, function (str, $1) {
    57                 return oJson[$1] ? oJson[$1] : '';
    58             });
    59         }
    60     },
    61     //根据指定格式如<%……%>绑定json数据
    62     TemplateEngine: function (html, options) {
    63         html = html.replace(/(&gt;)|(&lt;)/g, function (str, $1, $2) {
    64             switch (str) {
    65                 case $1:
    66                     return '>';
    67                 case $2:
    68                     return '<';
    69             }
    70         });
    71         var re = /<%([^%>]+)?%>/g, reExp = /(^( )?(if|for|else|switch|case|break|{|}))(.*)?/g, code = 'var r=[];
    ', cursor = 0;
    72         var add = function (line, js) {
    73             js ? (code += line.match(reExp) ? line + '
    ' : 'r.push(' + line + ');
    ') :
    74                 (code += line != '' ? 'r.push("' + line.replace(/"/g, '\"') + '");
    ' : '');
    75             return add;
    76         }
    77         while (match = re.exec(html)) {
    78             add(html.slice(cursor, match.index))(match[1], true);
    79             cursor = match.index + match[0].length;
    80         }
    81         add(html.substr(cursor, html.length - cursor));
    82         code += 'return r.join("");';
    83         return new Function(code.replace(/[
    	
    ]/g, '')).apply(options);
    84     }
    85 }

    1、第一种方式:${key}

    functionUtil.LoadJsonData(element, data);

    ”html“代码:

    1 <div id="data">
    2     <div class="item">
    3         姓名:${name}<br/>
    4         年龄:${age}<br/>
    5         职业:${job}<br/><br/>
    6     </div>
    7 </div>

    javascript代码:

     1 var data = [
     2            {
     3                     name: '徐磊',
     4                     age: 24,
     5                     job: 'IT'
     6                 },
     7                 {
     8                     name: '李磊',
     9                     age: 23,
    10                     job: '翻译'
    11                 }
    12     ];
    13 
    14 
    15 functionUtil.LoadJsonData('data', data);    

    执行结果:

    2、第二种方式<% 代码 %>

    functionUtil.TemplateEngine(string,Object);

    "html"代码:

     1 <div id="test3">
     2     <%if(this.isShow){
     3       for(var i in this.data){%>
     4         <p href="#">姓名:<%this.data[i].name%></p>
     5 
     6         <p href="#">年龄:<%this.data[i].age%></p>
     7 
     8         <p href="#">工作:<%this.data[i].job%></p>
     9         <br/>
    10     <%}}%>
    11 </div>

    javascript代码:

     1 var person = {
     2                 data: [
     3                     {
     4                         name: '徐磊',
     5                         age: 24,
     6                         job: 'IT'
     7                     },
     8                     {
     9                         name: '李磊',
    10                         age: 23,
    11                         job: '翻译'
    12                     }
    13                 ],
    14                 isShow: true
    15             }
    16 
    17 
    18    document.getElementById("test3").innerHTML = functionUtil.TemplateEngine(document.getElementById("test3").innerHTML, person);

    结果:

  • 相关阅读:
    BUG漏测的原因总结,以及如何处理
    费用流
    拉格朗日插值
    数论问题整理
    计数问题
    POJ 1741 Tree
    bzoj 2820: YY的GCD
    luogu P3690 【模板】Link Cut Tree (动态树)
    bzoj 1036: [ZJOI2008]树的统计Count
    bzoj 3282: Tree
  • 原文地址:https://www.cnblogs.com/goesby/p/4255987.html
Copyright © 2011-2022 走看看