Преобразование Json в HTML [дубликат]

Код:

  chdir ('путь / to / dir') или умереть «$!»;   

Perldoc:

  chdir EXPR chdir FILEHANDLE chdir DIRHANDLE chdir Изменяет рабочий каталог на EXPR, если это возможно.  Если EXPR опущен, изменения в каталоге, заданные в $ ENV {HOME}, если установлены;  если нет, изменения в каталог, указанный в ENV {LOGDIR}.  (В разделе VMS также проверяется переменная $ ENV {SYS $ LOGIN} и используется, если она установлена.) Если ни один из них не установлен, «chdir» ничего не делает.  Он возвращает true при успехе, false в противном случае.  См. Пример под «die».  В системах, поддерживающих fchdir, вы можете передать дескриптор файла или дескриптор каталога в качестве аргумента.  В системах, которые не поддерживают fchdir, передающие дескрипторы создают фатальную ошибку во время выполнения.   
83
задан Kara 29 July 2014 в 00:38
поделиться

4 ответа

Спасибо всем за ваши ответы. Я написал сам. Обратите внимание, что это использует jQuery.

Фрагмент кода:

var myList = [
  { "name": "abc", "age": 50 },
  { "age": "25", "hobby": "swimming" },
  { "name": "xyz", "hobby": "programming" }
];

// Builds the HTML Table out of myList.
function buildHtmlTable(selector) {
  var columns = addAllColumnHeaders(myList, selector);

  for (var i = 0; i < myList.length; i++) {
    var row$ = $('<tr/>');
    for (var colIndex = 0; colIndex < columns.length; colIndex++) {
      var cellValue = myList[i][columns[colIndex]];
      if (cellValue == null) cellValue = "";
      row$.append($('<td/>').html(cellValue));
    }
    $(selector).append(row$);
  }
}

// Adds a header row to the table and returns the set of columns.
// Need to do union of keys from all records as some records may not contain
// all records.
function addAllColumnHeaders(myList, selector) {
  var columnSet = [];
  var headerTr$ = $('<tr/>');

  for (var i = 0; i < myList.length; i++) {
    var rowHash = myList[i];
    for (var key in rowHash) {
      if ($.inArray(key, columnSet) == -1) {
        columnSet.push(key);
        headerTr$.append($('<th/>').html(key));
      }
    }
  }
  $(selector).append(headerTr$);

  return columnSet;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<body onLoad="buildHtmlTable('#excelDataTable')">
  <table id="excelDataTable" border="1">
  </table>
</body>

104
ответ дан Peter B 15 August 2018 в 15:43
поделиться

Запустите JSON2HTML http://json2html.com/ плагин для jQuery. Он позволяет указать преобразование, которое преобразует ваш объект JSON в шаблон HTML. Используйте builder на http://json2html.com/ , чтобы получить объект json transform для любого желаемого шаблона html. В вашем случае это будет таблица со строкой, имеющей следующее преобразование.

Пример:

var transform = {"tag":"table", "children":[
    {"tag":"tbody","children":[
        {"tag":"tr","children":[
            {"tag":"td","html":"${name}"},
            {"tag":"td","html":"${age}"}
        ]}
    ]}
]};

var data = [
    {'name':'Bob','age':40},
    {'name':'Frank','age':15},
    {'name':'Bill','age':65},
    {'name':'Robert','age':24}
];

$('#target_div').html(json2html.transform(data,transform));
8
ответ дан Deepak 15 August 2018 в 15:43
поделиться

Вы можете использовать простой jQuery jPut-плагин

http://plugins.jquery.com/jput/

<script>
$(document).ready(function(){

var json = [{"name": "name1","email":"email1@domain.com"},{"name": "name2","link":"email2@domain.com"}];
//while running this code the template will be appended in your div with json data
$("#tbody").jPut({
    jsonData:json,
    //ajax_url:"youfile.json",  if you want to call from a json file
    name:"tbody_template",
});

});
</script>   

<table jput="t_template">
 <tbody jput="tbody_template">
     <tr>
         <td>{{name}}</td>
         <td>{{email}}</td>
     </tr>
 </tbody>
</table>

<table>
 <tbody id="tbody">
 </tbody>
</table>
10
ответ дан Herman Schoenfeld 15 August 2018 в 15:43
поделиться

Я переписал ваш код в vanilla-js, используя методы DOM, чтобы предотвратить инъекцию html.

Демо

var _table_ = document.createElement('table'),
    _tr_ = document.createElement('tr'),
    _th_ = document.createElement('th'),
    _td_ = document.createElement('td');

// Builds the HTML Table out of myList json data from Ivy restful service.
 function buildHtmlTable(arr) {
     var table = _table_.cloneNode(false),
         columns = addAllColumnHeaders(arr, table);
     for (var i=0, maxi=arr.length; i < maxi; ++i) {
         var tr = _tr_.cloneNode(false);
         for (var j=0, maxj=columns.length; j < maxj ; ++j) {
             var td = _td_.cloneNode(false);
                 cellValue = arr[i][columns[j]];
             td.appendChild(document.createTextNode(arr[i][columns[j]] || ''));
             tr.appendChild(td);
         }
         table.appendChild(tr);
     }
     return table;
 }

 // Adds a header row to the table and returns the set of columns.
 // Need to do union of keys from all records as some records may not contain
 // all records
 function addAllColumnHeaders(arr, table)
 {
     var columnSet = [],
         tr = _tr_.cloneNode(false);
     for (var i=0, l=arr.length; i < l; i++) {
         for (var key in arr[i]) {
             if (arr[i].hasOwnProperty(key) && columnSet.indexOf(key)===-1) {
                 columnSet.push(key);
                 var th = _th_.cloneNode(false);
                 th.appendChild(document.createTextNode(key));
                 tr.appendChild(th);
             }
         }
     }
     table.appendChild(tr);
     return columnSet;
 }
41
ответ дан Oriol 15 August 2018 в 15:43
поделиться
  • 1
    Можно ли сделать эту работу с вложенным объектом json? – Janac Meena 10 August 2016 в 18:49
  • 2
    @JanacMeena Я думаю, для этого вам понадобятся n-мерные таблицы. – Oriol 10 August 2016 в 18:53
  • 3
    Это правда. Таблицы в таблицах. Кроме того, я обнаружил масштабируемые treemaps, которые позволяют вложенные json – Janac Meena 11 August 2016 в 15:20
  • 4
    Эта же функция, но возвращающая сводную таблицу, была бы красивой – ndelucca 8 November 2017 в 19:12
Другие вопросы по тегам:

Похожие вопросы: