浅谈javascript中自定义模版_javascript技巧
程序员文章站
2022-04-07 21:06:16
...
/** * Created by Administrator on 15-1-19. */ 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 绑定json数据 TemplateEngine: function (html, options) { html = html.replace(/(>)|('; case $2: return ']+)?%>/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(/[\r\t\n]/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"代码:
姓名:
年龄:
工作:
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模板有了新的认识了呢,希望大家能够喜欢。
推荐阅读
-
JavaScript中各种编码解码函数的区别和注意事项_javascript技巧
-
javascript中checkbox使用方法简单实例演示_javascript技巧
-
js中通过父级进行查找定位元素_javascript技巧
-
js和jquery中循环的退出和继续学习记录_javascript技巧
-
Javascript中的delete介绍_javascript技巧
-
javascript中bind函数的作用实例介绍_javascript技巧
-
js中利用tagname和id获取元素的方法_javascript技巧
-
JS中setInterval、setTimeout不能传递带参数的函数的解决方案_javascript技巧
-
js中事件的处理与浏览器对象示例介绍_javascript技巧
-
比较全面的event对像在IE与FF中的区别 推荐_javascript技巧