亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript根據json生成html表格的示例代碼

2019-11-19 12:38:27
字體:
來源:轉載
供稿:網友

之前公司有一個需求是:通過js來生成html。而且大部分都是生成表格,直接通過字符串拼接的話,代碼的可復用性太低的,所以寫了個通用的json轉html表格的工具。

代碼

htmlKit = {  _tags: [], html: [],   _createAttrs: function (attrs) {    var attrStr = [];    for (var key in attrs) {      if (!attrs.hasOwnProperty(key)) continue;      attrStr.push(key + "=" + attrs[key] + "")    }    return attrStr.join(" ")  },   _createTag: function (tag, attrs, isStart) {    if (isStart) {      return "<" + tag + " " + this._createAttrs(attrs) + ">"    } else {      return "</" + tag + ">"    }  },   start: function (tag, attrs) {    this._tags.push(tag);    this.html.push(this._createTag(tag, attrs, true))  },   end: function () {    this.html.push(this._createTag(this._tags.pop(), null, false))  },   tag: function (tag, attr, text) {    this.html.push(this._createTag(tag, attr, true) + text + this._createTag(tag, null, false))  },   create: function () {    return this.html.join("")  }};function json2Html(data) {  var hk = htmlKit;  hk.start("table", {"cellpadding": "10", "border": "1"});  hk.start("thead");  hk.start("tr");  data["heads"].forEach(function (head) {    hk.tag("th", {"bgcolor": "AntiqueWhite"}, head)  });  hk.end();  hk.end();  hk.start("tbody");  data["data"].forEach(function (dataList, i) {    dataList.forEach(function (_data) {      hk.start("tr");      data["dataKeys"][i].forEach(function (key) {        var rowsAndCol = key.split(":");        if (rowsAndCol.length === 1) {          hk.tag("td", null, _data[rowsAndCol[0]])        } else if (rowsAndCol.length === 3) {          hk.tag("td", {"rowspan": rowsAndCol[0], "colspan": rowsAndCol[1]}, _data[rowsAndCol[2]])        }      });      hk.end()    })  });  hk.end();  hk.end();  return hk.create()}

使用說明

HtmlKit

htmlKit是創建html標簽的工具

函數

函數名 作用 例子
start (tag, attrs) 創建未封閉標簽頭 start("table", {"cellpadding": "10", "border": "1"}),輸出<table cellpadding="10" border="1">
end () 創建上一個start函數的標簽尾 上面執行了start("table"),再執行end(),輸出</table>
tag (tag, attr, text) 創建封閉標簽 tag("th", {"bgcolor": "AntiqueWhite"}, "hello"),輸出<th bgcolor="AntiqueWhite">hello</th>

json2Html

json轉Html

例子:

var data = [  {    "chinese": 80,    "mathematics": 89,    "english": 90  }];var total = 0;data.forEach(function (value) {  for (key in value) {    total += value[key];  }});var htmlMetadata = {  "heads": ["語文", "數學", "英語"],  "dataKeys": [["chinese", "mathematics", "english"], ["text","1:2:total"]], // rowspan:colspan:value  "data": [data, [{"text": "合計","total": total}]]};var html = json2Html(htmlMetadata);console.info(html);輸出結果(結果為了好看,格式化了):<table cellpadding=10 border=1>  <thead>  <tr>    <th bgcolor=AntiqueWhite>語文</th>    <th bgcolor=AntiqueWhite>數學</th>    <th bgcolor=AntiqueWhite>英語</th>  </tr>  </thead>  <tbody>  <tr>    <td>80</td>    <td>89</td>    <td>90</td>  </tr>  <tr>    <td>合計</td>    <td rowspan=1 colspan=2>259</td>  </tr>  </tbody></table>

效果:

語文 數學 英語
80 89 90
合計 259

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩大片在线观看视频| 国产丝袜精品第一页| 在线亚洲午夜片av大片| 亚洲国产一区自拍| 国内免费精品永久在线视频| 亚洲欧洲在线观看| 91a在线视频| 国产精品夫妻激情| 欧美精品亚州精品| 91精品久久久久久久| 狠狠躁夜夜躁人人躁婷婷91| 欧美激情视频免费观看| 亚洲xxxx做受欧美| 91久久国产婷婷一区二区| 92国产精品视频| 亚洲一区精品电影| 日韩av三级在线观看| 55夜色66夜色国产精品视频| 91在线观看免费网站| 亚洲欧美日韩综合| 国产欧美精品xxxx另类| 欧美电影在线观看高清| 一本色道久久88精品综合| 最近中文字幕mv在线一区二区三区四区| www日韩中文字幕在线看| 色悠悠久久久久| 国产视频在线一区二区| 亚洲欧美日韩综合| 久久久国产视频91| 国产精品国内视频| 欧美另类交人妖| 亚洲日韩中文字幕在线播放| 成人h视频在线| 国产精品美女视频网站| 国产精品美女午夜av| 欧美极品少妇xxxxⅹ喷水| 国产精品久久婷婷六月丁香| 777精品视频| 欧美激情视频网站| 久久影视电视剧免费网站| 粗暴蹂躏中文一区二区三区| 国产一区二区三区毛片| 日韩欧美亚洲成人| 欧美一级片久久久久久久| 在线视频中文亚洲| 97精品一区二区三区| 亚洲国产日韩一区| 国产精品久久久久久网站| 欧美电影在线观看| 2025国产精品视频| 久操成人在线视频| 亚洲最大中文字幕| 亚洲在线视频观看| 亚洲天堂免费视频| 日韩av在线免费播放| 欧美大片大片在线播放| 欧美日韩一区二区在线播放| 国产ts人妖一区二区三区| 欧美高清理论片| 91天堂在线视频| 第一福利永久视频精品| 亚洲激情视频在线观看| 欧美综合在线观看| 亚洲电影免费观看高清完整版在线观看| 日本精品视频网站| 久久综合88中文色鬼| 97超级碰碰碰久久久| 欧美日韩国产综合新一区| 亚洲老板91色精品久久| 亚洲精品免费av| 日本精品视频在线观看| 亚洲国产女人aaa毛片在线| 一本大道亚洲视频| 91系列在线观看| 最近2019中文字幕mv免费看| 91av福利视频| 91chinesevideo永久地址| 欧美色播在线播放| 91精品国产综合久久男男| 日韩免费电影在线观看| 亚洲欧美在线一区二区| 91网站免费观看| 亚洲理论电影网| 国产中文字幕日韩| 亚洲国内精品视频| 欧美成人自拍视频| 成人中心免费视频| 国产成人精品视频在线| 国产成人在线播放| 久久夜色精品国产| 国产精品偷伦一区二区| 欧洲精品在线视频| 日本免费久久高清视频| 久久久久久这里只有精品| 中文字幕日韩欧美精品在线观看| 日韩视频一区在线| 亚洲国产一区二区三区四区| 国产手机视频精品| 国模叶桐国产精品一区| 欧美日韩中文字幕综合视频| 精品中文字幕在线观看| 亚洲国产婷婷香蕉久久久久久| 97久久超碰福利国产精品…| 亚洲影院高清在线| 在线观看日韩www视频免费| 欧美日韩综合视频网址| 亚洲精美色品网站| 欧美高清不卡在线| 视频一区视频二区国产精品| 欧美激情精品久久久久久变态| 国产午夜精品麻豆| 国产精品一区二区久久久久| 国产精品入口免费视| 国产精品综合不卡av| 日韩精品视频在线| 国产欧美在线播放| 在线视频国产日韩| 九九九热精品免费视频观看网站| 欧美精品免费播放| 亚洲精品国产电影| 色yeye香蕉凹凸一区二区av| 国产999视频| 欧美二区在线播放| 91高清免费在线观看| 亚洲午夜久久久久久久| 日韩成人激情视频| 色悠久久久久综合先锋影音下载| 国产精品视频不卡| 高跟丝袜欧美一区| 国产精品久久9| 国产91网红主播在线观看| 国产精品v日韩精品| 国产午夜精品视频免费不卡69堂| 欧美高清视频一区二区| 亚洲www永久成人夜色| 国产精品国产三级国产aⅴ浪潮| 国产精品视频导航| 亚洲理论在线a中文字幕| 91干在线观看| 亚洲欧美日韩中文在线制服| 亚洲网在线观看| 久久99久久99精品中文字幕| 国产999在线| 欧美日韩国产一区在线| 亚洲午夜未删减在线观看| 国产盗摄xxxx视频xxx69| 一本色道久久综合亚洲精品小说| 国产日韩欧美夫妻视频在线观看| 欧美一级电影久久| 色偷偷av亚洲男人的天堂| 青草青草久热精品视频在线网站| 亚洲午夜未删减在线观看| 久久久人成影片一区二区三区| 亚洲老司机av| 欧美黄网免费在线观看| 欧美综合激情网| 亚洲毛茸茸少妇高潮呻吟| 国产成人免费av| 不用播放器成人网| 欧美肥老妇视频| 亚洲xxxxx| 欧美午夜精品伦理| 色香阁99久久精品久久久| 美女久久久久久久|