栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

浅谈javascript中自定义模版

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

浅谈javascript中自定义模版


function functionUtil() {
}
functionUtil = {
  //某个DOM节点是否有某个属性
  hasAttr: function (el, name) {
    var attr = el.getAttributeNode && el.getAttributeNode(name);
    return attr ? attr.specified : false
  },
  //根据class获取元素
  getByClass: function (sClass, oParent) {
    oParent = oParent || document;
    if (!oParent.getElementsByClassName) {
      return oParent.getElementsByClassName(sClass);
    }
    var arr = [];
    var aEle = oParent.getElementsByTagName('*');
    var reg = new RegExp('(^|\s)' + sClass + '(\s|$)');
    //var reg = new RegExp('(^|[\x20\t\r\n\f])' + sClass + '([\x20\t\r\n\f]|$)');
    for (var i = 0; i < aEle.length; i++) {
      if (reg.test(aEle[i].className)) {
 arr.push(aEle[i]);
      }
    }
    return arr;
  },
  //动态添加样式表
  addSheetFile: function (path) {
    var fileref = document.createElement("link")
    fileref.rel = "stylesheet";
    fileref.type = "text/css";
    fileref.href = path;
    fileref.media = "screen";
    var headobj = document.getElementsByTagName('head')[0];
    headobj.appendChild(fileref);
  },
  //根据指定格式如 ${name} 绑定json数据
  LoadJsondata: function (sParent, oJson) {
    var oParent = document.getElementById(sParent);
    if (oJson instanceof Array) {
      var str = oParent.innerHTML;
      for (var i = 0; i < oJson.length - 1; i++) {
 oParent.innerHTML += str;
      }
      for (var d in oJson) {
 oParent.children[d].innerHTML = oParent.children[d].innerHTML.replace(/${(w+)}/g, function (str, $1) {
   return oJson[d][$1] ? oJson[d][$1] : '';
 });
      }
    } else {
      oParent.innerHTML = oParent.innerHTML.replace(/${(w+)}/g, function (str, $1) {
 return oJson[$1] ? oJson[$1] : '';
      });
    }
  },
  //根据指定格式如<%……%>绑定json数据
  TemplateEngine: function (html, options) {
    html = html.replace(/(>)|(<)/g, function (str, $1, $2) {
      switch (str) {
 case $1:
   return '>';
 case $2:
   return '<';
      }
    });
    var re = /<%([^%>]+)?%>/g, reExp = /(^( )?(if|for|else|switch|case|break|{|}))(.*)?/g, code = 'var r=[];n', cursor = 0;
    var add = function (line, js) {
      js ? (code += line.match(reExp) ? line + 'n' : 'r.push(' + line + ');n') :
 (code += line != '' ? 'r.push("' + line.replace(/"/g, '\"') + '");n' : '');
      return add;
    }
    while (match = re.exec(html)) {
      add(html.slice(cursor, match.index))(match[1], true);
      cursor = match.index + match[0].length;
    }
    add(html.substr(cursor, html.length - cursor));
    code += 'return r.join("");';
    return new Function(code.replace(/[rtn]/g, '')).apply(options);
  }
}

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

functionUtil.LoadJsonData(element, data);

”html“代码:


  
    姓名:${name}
年龄:${age}
职业:${job}

javascript代码:

var data = [
      {
   name: '徐磊',
   age: 24,
   job: 'IT'
 },
 {
   name: '李磊',
   age: 23,
   job: '翻译'
 }
  ];


functionUtil.LoadJsonData('data', data);

执行结果:

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

functionUtil.TemplateEngine(string,Object);

"html"代码:


  <%if(this.isShow){
   for(var i in this.data){%>
    

姓名:<%this.data[i].name%>

年龄:<%this.data[i].age%>

工作:<%this.data[i].job%>


<%}}%>

javascript代码:

var person = {
 data: [
   {
     name: '徐磊',
     age: 24,
     job: 'IT'
   },
   {
     name: '李磊',
     age: 23,
     job: '翻译'
   }
 ],
 isShow: true
      }


  document.getElementById("test3").innerHTML = functionUtil.TemplateEngine(document.getElementById("test3").innerHTML, person);

结果:

以上就是本文的全部内容了,小伙伴们看完是否对javascript模板有了新的认识了呢,希望大家能够喜欢。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/104277.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号