Я столкнулся с проблемой при создании таблицы HTML с данными JSON, так как я новичок в этом, поэтому не могу правильно написать логику.
У меня есть данные json, из которых я должен создать динамическую таблицу html. Дизайн таблицы немного сложен, поэтому я не могу заполнить таблицу HTML правильными данными.
Из моего JSON я пытаюсь создать:
но не в состоянии.
Я сделал что-то вроде этого
var data = [{
"billdate": "2018-08-01",
"outlet": "S0001",
"amount": 291589,
"cash": 288276,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 3313,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-01",
"outlet": "S0002",
"amount": 58337,
"cash": 56727,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 1610,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-01",
"outlet": "S0009",
"amount": 65970,
"cash": 65970,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 0,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0001",
"amount": 296125,
"cash": 290480,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 5645,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0002",
"amount": 56545,
"cash": 55034,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 1511,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0009",
"amount": 72213,
"cash": 72213,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 0,
"kb": 0,
"bigbasket": 0
}
]
let formatData = function(data) {
let billdates = [];
let outlets = [];
data.forEach(element => {
if (billdates.indexOf(element.billdate) == -1) {
billdates.push(element.billdate);
}
if (outlets.indexOf(element.outlet) == -1) {
outlets.push(element.outlet);
}
});
return {
data: data,
billdates: billdates,
outlets: outlets,
};
};
let renderTable = function(data) {
billdates = data.billdates;
outlets = data.outlets;
data = data.data;
let tbl = document.getElementById("tblOlSalesSummary");
let table = document.createElement("table");
let thead = document.createElement("thead");
let headerRow = document.createElement("tr");
let th = document.createElement("th");
th.innerHTML = "BillDate";
th.classList.add("text-center");
headerRow.appendChild(th);
let grandTotal = 0;
let outletWiseTotal = {};
th = document.createElement("th");
th.innerHTML = "Sales Type";
th.classList.add("text-center");
headerRow.appendChild(th);
outlets.forEach(element => {
th = document.createElement("th");
th.innerHTML = element;
th.classList.add("text-center");
headerRow.appendChild(th);
outletWiseTotal[element] = 0;
data.forEach(el => {
if (el.outlet == element) {
outletWiseTotal[element] += parseInt(el.amount);
}
});
grandTotal += outletWiseTotal[element];
});
thead.appendChild(headerRow);
headerRow = document.createElement("tr");
th = document.createElement("th");
th.innerHTML = "Total";
th.classList.add("text-center");
headerRow.appendChild(th);
outlets.forEach(element => {
th = document.createElement("th");
th.innerHTML = outletWiseTotal[element].toLocaleString('en-in');
th.classList.add("text-right");
headerRow.appendChild(th);
});
th = document.createElement("th");
th.innerHTML = grandTotal.toLocaleString('en-in');
th.classList.add("text-right");
/* console.info(grandTotal); */
// headerRow.appendChild(th);
headerRow.insertBefore(th, headerRow.children[1]);
thead.appendChild(headerRow);
table.appendChild(thead);
let tbody = document.createElement("tbody");
billdates.forEach(element => {
let row = document.createElement("tr");
td = document.createElement("td");
td.innerHTML = element;
row.appendChild(td);
let total = 0;
outlets.forEach(outlet => {
let el = 0;
data.forEach(d => {
if (d.billdate == element && d.outlet == outlet) {
total += parseInt(d.cash);
el = d.cash;
}
});
td = document.createElement("td");
td.innerHTML = el.toLocaleString('en-in');
td.classList.add("text-right");
row.appendChild(td);
});
/* console.info("row is : " , row.children ) */
td = document.createElement("td");
td.innerHTML = total.toLocaleString('en-in');
td.classList.add("text-right");
// row.appendChild(td);
row.insertBefore(td, row.children[1]);
tbody.appendChild(row);
});
table.appendChild(tbody);
tbl.innerHTML = "";
tbl.appendChild(table);
table.classList.add("table");
table.classList.add("table-striped");
table.classList.add("table-bordered");
table.classList.add("table-hover");
}
let formatedData = formatData(data);
renderTable(formatedData);<script src = "https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel = "stylesheet" href = "https://stackpath.bootstrapcdn.com/bootstrap/4.1.2/css/bootstrap.min.css">
<div align = "center">
<table id = "tblOlSalesSummary">
</table>
</div>Как вы можете посмотреть на мое изображение, я должен зацикливать данные по дате выставления счетов, вот где я застрял. Изображение, которое я загрузил, просто для примера, пожалуйста, не сопоставляйте значения там, все значения изображения и моего JSON разные, но Full TotalTotal следует рассчитывать только на основе этого.
Я знаю, как создать динамическую таблицу, но здесь я застрял в каком-то циклическом сценарии.
Моя таблица полностью динамическая, все данные поступают из БД на основе выбора пользователя.
Я добавил сумму в свои данные JSON, которая является общей суммой по дате выставления счета, поэтому нет необходимости вычислять ее с помощью кодирования.
Сумма: total дата для каждой торговой точки



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Может поможет. Вы должны организовать свои данные, а затем построить таблицу с логикой
построить массив со всеми Sx и totalvalues построить массив со всеми датами и итоговыми значениями построить массив с суммами и т.д
table:
head and row
- date cell
- sales cell
- foreach Sx a cell
another row
- empty cell
- fulltotal cell
- foreach Sx totalvalues cells
body
foreach date a row with
- date cell
- total cell
- totalvalues cells on each Sx
forech field in date a row with
- empty cell
- name cell
- foreach sX a cell with value
но расчет я не могу сделать .. я немного слаб в логике и основах, поэтому задал вопрос .. если вы можете сделать какой-нибудь полезный код, это было бы очень полезно
вам нужно отделить общую сборку от сборки html, поэтому, когда у вас есть все данные, которые вы хотите в массивах, вы можете построить таблицу и получить итоги отсюда, например,outletWiseTotal, использовать функцию formatData для сохранения ключей и итогов, а затем построить
@ вы говорите amount, что я вызываю из бэкэнда, я должен рассчитывать здесь только в javascript?
outputWiseTotal, grandTotal, total += parseInt(d.cash) Все это на javascript?
OutletWiseTotal у меня есть в моем JSON, так как amount общая сумма равна full total, которая должна быть рассчитана в javascript
пожалуйста, помогите, если можете, пожалуйста
У меня есть вывод, аналогичный изображению, которое вы разместили. Единственный возможный недостаток моего кода заключается в том, что ему нужен жестко закодированный массив «типов продаж», поэтому, если данные json непротиворечивы и не изменятся, этот код можно использовать , иначе несложно разобрать объект и каждый раз создавать новый массив "типов продаж".
Основная идея заключается в том, что я проанализировал основной объект и преобразовал его в этот объект:
Object{
date1:{
outlet1: {
service1: value,
service2: value
},
outlet2: {
service1: value,
service2: value
}
}
date2:{
outlet1: {
service1: value,
service2: value
}
...and so on
}
А затем цикл по этому объекту для отображения таблицы в DOM.
var data = [{
"billdate": "2018-08-01",
"outlet": "S0001",
"amount": 291589,
"cash": 288276,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 3313,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-01",
"outlet": "S0002",
"amount": 58337,
"cash": 56727,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 1610,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-01",
"outlet": "S0009",
"amount": 65970,
"cash": 65970,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 0,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0001",
"amount": 296125,
"cash": 290480,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 5645,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0002",
"amount": 56545,
"cash": 55034,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 1511,
"kb": 0,
"bigbasket": 0
},
{
"billdate": "2018-08-02",
"outlet": "S0009",
"amount": 72213,
"cash": 72213,
"creditcard": 0,
"coupon": 0,
"paytm": 0,
"credit": 0,
"swiggy": 0,
"kb": 0,
"bigbasket": 0
}
]
let formatData = function(data) {
let formattedData = {};
data.forEach(element => {
if (!formattedData.hasOwnProperty(element.billdate)){
formattedData[element.billdate] = {};
}
});
Object.keys(formattedData).forEach(function(key) {
//console.info(key, formattedData[key]);
data.forEach(element => {
if (key == element.billdate){
formattedData[key][element.outlet] = {'amount': element.amount,
'cash': element.cash,
'creditcard': element.creditcard,
'coupon': element.coupon,
'paytm': element.paytm,
'credit': element.credit,
'swiggy': element.swiggy,
'kb': element.kb,
'bigbasket': element.bigbasket
};
}
});
});
//console.info(formattedData);
return formattedData;
}
let renderTable = function(data) {
//console.info(data);
let tbl = document.getElementById("tblOlSalesSummary");
let table = document.createElement("table");
let thead = document.createElement("thead");
let headerRow = document.createElement("tr");
let th = document.createElement("th");
th.innerHTML = "BillDate";
th.classList.add("text-center");
headerRow.appendChild(th);
th = document.createElement("th");
th.innerHTML = "Sales Type";
th.classList.add("text-center");
headerRow.appendChild(th);
let outletArray = [];
Object.keys(data).forEach(element => {
let obj = data[element];
//console.info(obj);
Object.keys(obj).forEach(elem => {
if (outletArray.indexOf(elem) == -1){
outletArray.push(elem);
}
});
});
//console.info(outletArray);
outletArray.forEach(element => {
th = document.createElement("th");
th.innerHTML = element;
th.classList.add("text-center");
headerRow.appendChild(th);
});
thead.appendChild(headerRow);
table.appendChild(thead);
let tbody = document.createElement("tbody");
//full total
let fullTotal = {};
outletArray.forEach(elem => {
fullTotal[elem] = 0;
Object.keys(data).forEach(element => {
fullTotal[elem] += data[element][elem]["amount"];
})
})
//console.info(fullTotal);
let row = document.createElement("tr");
td = document.createElement("td");
td.innerHTML = "";
row.appendChild(td);
td = document.createElement("td");
td.innerHTML = "Full Total";
row.appendChild(td);
Object.keys(fullTotal).forEach(elem =>{
td = document.createElement("td");
td.innerHTML = fullTotal[elem];
row.appendChild(td);
})
tbody.appendChild(row);
let salesTypes = ["amount","cash","creditcard","coupon","paytm","credit","swiggy","kb","bigbasket"];
Object.keys(data).forEach(element => {
let salesTypesIndex = 0;
salesTypes.forEach(elem => {
let row = document.createElement("tr");
td = document.createElement("td");
if (salesTypesIndex == 0){
td.innerHTML = element;
}else{
td.innerHTML = "";
}
row.appendChild(td);
td = document.createElement("td");
if (elem == "amount"){
td.innerHTML = "Totals";
}else{
td.innerHTML = elem;
}
row.appendChild(td);
outletArray.forEach(elem2 => {
let value = data[element][elem2][elem];
//console.info("value:",value);
td = document.createElement("td");
td.innerHTML = value;
row.appendChild(td);
})
/* console.info("row is : " , row.children ) */
tbody.appendChild(row);
salesTypesIndex++;
})
});
table.appendChild(tbody);
tbl.innerHTML = "";
tbl.appendChild(table);
table.classList.add("table");
table.classList.add("table-striped");
table.classList.add("table-bordered");
table.classList.add("table-hover");
}
let formattedData = formatData(data);
renderTable(formattedData);<script src = "https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel = "stylesheet" href = "https://stackpath.bootstrapcdn.com/bootstrap/4.1.2/css/bootstrap.min.css">
<div align = "center">
<table id = "tblOlSalesSummary">
</table>
</div>тип продаж не жестко запрограммирован, в любом случае я нашел решение
@viveksingh, конечно, я просто жестко запрограммировал для простоты, но его можно легко создать каждый раз из ответа json.
Не прямое решение, но, черт возьми. Используйте HTML-шаблоны, никто быстро не поймет, как строится ваша таблица. Например: handlebarsjs.com