Цикл строит таблицу только с одной строкой и 4 ячейками таблицы, даже если это большая таблица, поэтому я не могу применить правило четной / нечетной строки через CSS для создания раздетой таблицы.
Это мойкод и то, что я пытался:
<!DOCTYPE html>
<html lang="en">
<head>
<title>News</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js"></script>
<style>
/* Make the image fully responsive */
.carousel-inner img {
width: 100%;
height: 100%;
}
div {
background-color: gainsboro;
overflow: hidden;
column: hover{
background-color: blue;}
}
a {
color : blue;
}
a:visited { text-decoration: none; color:blue; }
table{
font-family: 'lato', sans-serif;
}
td {
border: 3px solid black;
font-size: 18px;
}
tr:hover{
background-color: grey;
}
table.y tr:nth-child(even) {
background: #CCC;}
table.y tr:nth-child(odd) {
background: #FFF;}
table.x tr:nth-child(even) {
background: #CCC;}
table.x tr:nth-child(odd) {
background: #FFF;}
th {
border: 3px solid black;
background-color: #95A5A6;
font-size: 22px;
font-weight: bold;
}
</style>
</head>
<body>
<div id="demo" class="carousel slide " data-ride="carousel" data-interval="15000">
<!-- Indicators -->
<ul class="carousel-indicators ">
<li data-target="#demo" data-slide-to="0" class="active"></li>
<li data-target="#demo" data-slide-to="1"></li>
<li data-target="#demo" data-slide-to="2"></li>
</ul>
<!-- The slideshow -->
<div class="carousel-inner div ">
<div class="carousel-item active ">
<div style=" float: left; display: inline-block ; width: 47% ; height: 50%">
<div class="feedgrabbr_widget" id="fgid_9004bf5532f2fddc801945a77"></div>
<script>if (typeof (fg_widgets) === "undefined") fg_widgets = new Array(); fg_widgets.push("fgid_9004bf5532f2fddc801945a77");</script>
<script async src="https://www.feedgrabbr.com/widget/fgwidget.js"></script>
</div>
<!-- Novo feed -->
<div style="float:right ; display: inline-block; width: 47%; height: 50%; ">
<div class="feedgrabbr_widget" id="fgid_67583148e205d7d628f4f1741"></div>
<script>if (typeof (fg_widgets) === "undefined") fg_widgets = new Array(); fg_widgets.push("fgid_67583148e205d7d628f4f1741");</script>
<script async src="https://www.feedgrabbr.com/widget/fgwidget.js"></script>
</div>
<!-- fim nfeed -->
</div>
<div class="carousel-item div" style="overflow: hidden">
<div id="piechart" style="width: 60%; height: 500px; float: left; display: inline-block"></div>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script
<!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<!-- Include all compiled plugins (below), or include individual files as needed -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css"></script>
<script type="text/javascript">
// Load google charts
google.charts.load('current', { 'packages': ['corechart'] });
google.charts.setOnLoadCallback(drawChart);
var matrix = [];
for (var i = 0; i < 50; i++) {
matrix[i] = new Array(2);
}
var j = 0;
$.getJSON("ofensas.json", function (data) {
$.each(data, function (key, val) {
matrix[j][0] = (val.offense_name);
matrix[j][1] = (val.count);
j++;
});
});
// Draw the chart and set the chart values
function drawChart() {
var data = google.visualization.arrayToDataTable([
['Ofensa', 'Total'],
[matrix[0][0], matrix[0][1]],
[matrix[1][0], matrix[1][1]],
[matrix[2][0], matrix[2][1]],
[matrix[3][0], matrix[3][1]],
[matrix[4][0], matrix[4][1]]
]);
// Set chart options
var options = {
'title': 'Gráfico de Ofensas',
'titleFontSize': 20,
'width': 830,
'height': 400,
'backgroundColor': 'gainsboro',
'fontSize' : 13
};
// Display the chart inside the <div> element with id="piechart"
var chart = new google.visualization.PieChart(document.getElementById('piechart'));
chart.draw(data, options);
}
</script>
<!-- parte adicionada -->
<table id="tab1" class = "x" style=" width: 40% ; height: 70px ; overflow: hidden ; float: right ">
<tr style="border: 3px solid black">
<th style=" width: 50%">Ofensa</th>
<th style=" width: 25%">Atribuída a:</th>
<th style=" width: 25%">Severidade(0 a 10): </th>
</tr>
</table>
<script>
$.getJSON("severas.json", function (data) {
var items = [];
var i = 0;
$.each(data, function (key, val) {
items.push("<tr>");
items.push("<td name='" + key + "'>" + val.description + "</td>");
items.push("<td entregue='" + key + "'>" + val.assigned_to + "</td>");
items.push("<td severidade='" + key + "'>" + val.severity + "</td>");
items.push("</tr>");
i++;
});
$("<tbody/>", { html: items.join("") }).appendTo(document.getElementById('tab1'));
});
</script>
<!-- fim -->
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script type="text/javascript">
google.charts.load("current", {packages:['corechart']});
google.charts.setOnLoadCallback(drawChart);
var matrix = [];
for(var i=0; i<50; i++) {
matrix[i] = new Array(2);
}
var j=0;
$.getJSON("ofensas.json",function(data){
$.each(data, function(key, val){
matrix[j][0]=(val.offense_name);
matrix[j][1]=(val.count);
j++;
});
});
function drawChart() {
var data = google.visualization.arrayToDataTable([
["Element", "Density", { role: "style" } ],
[matrix[0][0], matrix[0][1], "red"],
[matrix[1][0], matrix[1][1], "yellow"],
[matrix[2][0], matrix[2][1], "green"],
[matrix[3][0], matrix[3][1], "grey"]
]);
var view = new google.visualization.DataView(data);
view.setColumns([0, 1,
{ calc: "stringify",
sourceColumn: 1,
type: "string",
role: "annotation" },
2]);
var options = {
title: "Ofensas mais frequentes",
width: 900,
height: 300,
bar: {groupWidth: "95%"},
legend: { position: "none" },
'backgroundColor':'gainsboro',
'font-size': 13,
'titleFontSize': 20
};
var chart = new google.visualization.ColumnChart(document.getElementById("columnchart_values"));
chart.draw(view, options);
<!--options-->
}
</script>
<div id="columnchart_values" style="width: 900px; height: 800px; display: inline-block;"></div>
</div>
<div class="carousel-item">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<table id="tab2" class="y" >
<tr >
<th >Aplicacao</th>
<th>Data</th>
<th>Referencias</th>
<th>Vulnerabilidade</th>
</tr>
</table>
<!-- this is the table where I am having problems making it stripped -->
<script>
const software = ["7zip.json", "acrobat_reader_dc.json", "air.json" , "bitdefender.json", "chrome.json", "cma_system_software.json", "flash_player.json", "net_framework.json", "notepad%2b%2b.json", "office.json", "recuva.json", "remote_desktop_connection.json", "silverlight.json", "skype_for_business.json", "sumatrapdf.json", "system_center_configuration_manager.json", "visio_viewer.json", "vlc_media_player.json", "vsphere_client.json", "windows.json"];
const app = ["7zip", "Acrobat Reader DC", "Air" , "Bitdefender", "Chrome", "Cma system software", "Flash Player", "net framework", "Notepad++", "Office", "Recuva", "Remote Desktop Connection", "Silverlight", "Skype for Business", "Sumatrapdf", "System Center Configuration_manager", "Visio Viewer", "VLC Media Player", "Vsphere Client", "Windows.json"];
var r=0;
for (m = 0; m < 19; m++) {
$.getJSON(software[m], function (data) {
var items = [];
var i = 0;
$.each(data, function (key, val) {
<!-- this is what I was trying -->
<!-- x++;-->
<!-- if(x % 2 === 0){-->
<!--$("tr").css("background", "red");-->
while(i< 1 && val.summary!= null)
{
items.push("<tr>");
items.push("<td name='" + key + "'>" + app[r] + "</td>");
items.push("<td date='" + key + "'>" + val.Modified + "</td>");
items.push("<td reference='" + key +"'>" + "<a href='"+ val.references[0] + "'</a>" + "Mais Detalhes" + "</td>");
items.push("<td vulnerability='" + key + "'>" + val.summary + "</td>");
items.push("</tr>");
i++;
}
});
$("<tbody/>", { html: items.join("") }).appendTo(document.getElementById('tab2'));
r++;
});
}
</script>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo" data-slide="prev" style="width: 20px">
<span class="carousel-control-prev-icon"></span>
</a>
<a class="carousel-control-next" href="#demo" data-slide="next" style="width: 20px">
<span class="carousel-control-next-icon"></span>
</a>
</div>
</div>
</body>
</html>
tab2 с классом "y"
Вот весь HTML-файл с изображением в конце таблицы, котороеЯ не могу раздеться.Также есть некоторые комментарии, где эта таблица генерируется.