淺談javascript中自定義模版
/** * Created by Administrator on 15-1-19. */ function functionUtil() { } functionUtil = { //某個DOM節(jié)點(diǎn)是否有某個屬性 hasAttr: function (el, name) { var attr = el.getAttributeNode && el.getAttributeNode(name); return attr ? attr.specified : false }, //根據(jù)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; }, //動態(tài)添加樣式表 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); }, //根據(jù)指定格式如 ${name} 綁定json數(shù)據(jù) 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] : ''; }); } }, //根據(jù)指定格式如<%……%>綁定json數(shù)據(jù) 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(/[\r\t\n]/g, '')).apply(options); } }
1、第一種方式:${key}
functionUtil.LoadJsonData(element, data);
”html“代碼:
<div id="data"> <div class="item"> 姓名:${name}<br/> 年齡:${age}<br/> 職業(yè):${job}<br/><br/> </div> </div>
javascript代碼:
var data = [ { name: '徐磊', age: 24, job: 'IT' }, { name: '李磊', age: 23, job: '翻譯' } ]; functionUtil.LoadJsonData('data', data);
執(zhí)行結(jié)果:
2、第二種方式<% 代碼 %>
functionUtil.TemplateEngine(string,Object);
"html"代碼:
<div id="test3"> <%if(this.isShow){ for(var i in this.data){%> <p href="#">姓名:<%this.data[i].name%></p> <p href="#">年齡:<%this.data[i].age%></p> <p href="#">工作:<%this.data[i].job%></p> <br/> <%}}%> </div>
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);
結(jié)果:
以上就是本文的全部內(nèi)容了,小伙伴們看完是否對javascript模板有了新的認(rèn)識了呢,希望大家能夠喜歡。
相關(guān)文章
基于原生js實(shí)現(xiàn)九宮格算法代碼實(shí)例
這篇文章主要介紹了基于原生js實(shí)現(xiàn)九宮格算法代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07Three.js開發(fā)實(shí)現(xiàn)3D地圖的實(shí)踐過程總結(jié)
這篇文章主要給大家介紹了關(guān)于利用Three.js開發(fā)實(shí)現(xiàn)3D地圖的實(shí)踐過程,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用three.js具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11詳解cesium實(shí)現(xiàn)大批量POI點(diǎn)位聚合渲染優(yōu)化方案
這篇文章主要為大家介紹了cesium實(shí)現(xiàn)大批量POI點(diǎn)位聚合渲染優(yōu)化方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05用函數(shù)式編程技術(shù)編寫優(yōu)美的 JavaScript_ibm
函數(shù)式編程語言在學(xué)術(shù)領(lǐng)域已經(jīng)存在相當(dāng)長一段時間了,但是從歷史上看,它們沒有豐富的工具和庫可供使用。隨著 .NET 平臺上的 Haskell 的出現(xiàn),函數(shù)式編程變得更加流行。一些傳統(tǒng)的編程語言,例如 C++ 和 JavaScript,引入了由函數(shù)式編程提供的一些構(gòu)造和特性。在許多情況下,JavaScript 的重復(fù)代碼導(dǎo)致了一些拙劣的編碼。如果使用函數(shù)式編程,就可以避免這些問題。此外,可以利用函數(shù)式編程風(fēng)格編寫更加優(yōu)美的回調(diào)。2008-05-05TypeScript內(nèi)置工具類型快速入門運(yùn)用
TypeScript 中內(nèi)置了很多工具類型,我們無需導(dǎo)入,可以直接使用。 其中的很多都是比較常用的,接下來我們根據(jù)使用范圍來一一介紹,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-03-03