浅谈javascript中自定义模版_javascript技巧
程序员文章站
2023-12-22 11:37:58
...
/** * 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字符串与数组_javascript技巧
-
javascript 中的 delete及delete运算符_javascript技巧
-
Chrome中模态对话框showModalDialog返回值问题的解决方法_javascript技巧
-
现代JavaScript使用技巧之ES6中的简写语法
-
浅谈javascript中数组Array的添加/删除操作
-
基于Android中Webview使用自定义的javascript进行回调的问题详解
-
浅谈JavaScript中的apply/call/bind和this的使用
-
浅谈JavaScript中的Math.atan()方法的使用
-
详解JavaScript中的自定义事件编写