Как применить четные / нечетные различные строки цвета фона через Jquery - PullRequest
0 голосов
/ 05 февраля 2019

Цикл строит таблицу только с одной строкой и 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-файл с изображением в конце таблицы, котороеЯ не могу раздеться.Также есть некоторые комментарии, где эта таблица генерируется.

Ответы [ 2 ]

0 голосов
/ 13 февраля 2019

Получил решение.Пришлось использовать чистый код Jquery для того, чтобы его убрали

$('table tr:even:not(:first)').css('background-color','#ededed');

Спасибо всем за потраченное время

0 голосов
/ 05 февраля 2019

почему вы думаете, что вы не можете сделать это, используя только css?

вы можете выбирать четные и нечетные строки, используя селектор nth-child

tbody tr:nth-child(odd) {
  background-color: #DDD;
}
<table>
  <thead>
  <tr>
    <th>column 1</th>
    <th>column 2</th>
    <th>column 3</th>
  </tr>
  </thead>
  <tbody>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
    <tr><td>a</td><td>b</td><td>c</td></tr>
  </tbody>
</table>
...