欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談javascript中自定義模版

 更新時間:2015年01月29日 09:07:33   作者:一起走過的日子  
本文向我們簡單介紹了javascript中自定義模板的2種方法,圖文并茂,十分詳細,這里推薦給小伙伴們。
/**
 * Created by Administrator on 15-1-19.
 */
function functionUtil() {
}
functionUtil = {
  //某個DOM節(jié)點是否有某個屬性
  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;
  },
  //動態(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);
  },
  //根據指定格式如 ${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(/(&gt;)|(&lt;)/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í)行結果:

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);

結果:

以上就是本文的全部內容了,小伙伴們看完是否對javascript模板有了新的認識了呢,希望大家能夠喜歡。

相關文章

  • 微信小程序swiper禁止用戶手動滑動代碼實例

    微信小程序swiper禁止用戶手動滑動代碼實例

    這篇文章主要介紹了微信小程序swiper禁止用戶手動滑動代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • 基于原生js實現九宮格算法代碼實例

    基于原生js實現九宮格算法代碼實例

    這篇文章主要介紹了基于原生js實現九宮格算法代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • Three.js開發(fā)實現3D地圖的實踐過程總結

    Three.js開發(fā)實現3D地圖的實踐過程總結

    這篇文章主要給大家介紹了關于利用Three.js開發(fā)實現3D地圖的實踐過程,文中通過示例代碼介紹的非常詳細,對大家學習或者使用three.js具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • 詳解cesium實現大批量POI點位聚合渲染優(yōu)化方案

    詳解cesium實現大批量POI點位聚合渲染優(yōu)化方案

    這篇文章主要為大家介紹了cesium實現大批量POI點位聚合渲染優(yōu)化方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • JavaScript中Promise的使用詳解

    JavaScript中Promise的使用詳解

    Promise,相信每一個前端工程師都或多或少地在項目中都是用過,畢竟它早已不是一個新名詞。ES6中已經原生對它加以支持,在caniuse中搜索一下 Promise ,發(fā)現新版的chrome和firefox也已經支持。但是低版本的瀏覽器我們可以使用 es6-promise 這個 polyfill 庫來加以兼容。
    2017-02-02
  • stackoverflow常用工具庫總結

    stackoverflow常用工具庫總結

    這篇文章主要為大家介紹了stackoverflow常用工具庫總結,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • JavaScript中常見的幾種獲取元素的方式

    JavaScript中常見的幾種獲取元素的方式

    這篇文章主要介紹了JavaScript中常見的幾種獲取元素的方式,需要的朋友可以參考下
    2023-05-05
  • 用函數式編程技術編寫優(yōu)美的 JavaScript_ibm

    用函數式編程技術編寫優(yōu)美的 JavaScript_ibm

    函數式編程語言在學術領域已經存在相當長一段時間了,但是從歷史上看,它們沒有豐富的工具和庫可供使用。隨著 .NET 平臺上的 Haskell 的出現,函數式編程變得更加流行。一些傳統(tǒng)的編程語言,例如 C++ 和 JavaScript,引入了由函數式編程提供的一些構造和特性。在許多情況下,JavaScript 的重復代碼導致了一些拙劣的編碼。如果使用函數式編程,就可以避免這些問題。此外,可以利用函數式編程風格編寫更加優(yōu)美的回調。
    2008-05-05
  • 無間斷滾動marquee的詳細用法解析

    無間斷滾動marquee的詳細用法解析

    無間斷滾動marquee的詳細用法解析...
    2006-08-08
  • TypeScript內置工具類型快速入門運用

    TypeScript內置工具類型快速入門運用

    TypeScript 中內置了很多工具類型,我們無需導入,可以直接使用。 其中的很多都是比較常用的,接下來我們根據使用范圍來一一介紹,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-03-03

最新評論