Freeze Footer (Total Row) в таблице HTML / CSS / JS - PullRequest
0 голосов
/ 04 марта 2019

Я использую JSgrid и пытаюсь заморозить нижний колонтитул (общая строка).Не будет нумерации страниц, поэтому всякий раз, когда новая строка добавляется из базы данных, она должна переходить в прокрутку, а нижний колонтитул (общая строка) должен оставаться статическим (позиция: фиксированная).Я попытался применить позицию, z index, но, похоже, я где-то ошибаюсь.Пожалуйста, помогите мне.

Мой код, как показано ниже:

    var data = [
        {
            "Name": "Product",
            "Sum": 10
        },
        {
            "Name": "Another Product",
            "Sum": 20
        },
        {
            "Name": "Third Product",
            "Sum": 30
        },
         {
            "Name": "Third Product",
            "Sum": 30
        },
         {
            "Name": "Third Product",
            "Sum": 30
        },
         {
            "Name": "Third Product",
            "Sum": 30
        },
         {
            "Name": "Third Product",
            "Sum": 30
        },
         {
            "Name": "Third Product",
            "Sum": 30
        }
    ];
    
    $("#jsGrid").jsGrid({
            width: "100%",
            height: "270px",
     
            autoload: true,
            inserting: true,
     
            controller: {
            	loadData: function() {
              	return data;
              }
            },
            
            onRefreshed: function(args) {
            	var items = args.grid.option("data");
              var total = { Name: "Total", "Sum": 0, IsTotal: true };
              
              items.forEach(function(item) {
              	total.Sum += item.Sum;
              });
              
              var $totalRow = $("<tr>").addClass("total-row");
              
              args.grid._renderCells($totalRow, total);
              
              args.grid._content.append($totalRow);
            },
            
            fields: [
                { name: "Name", title:"Product", type: "text", width: "60%", validate: "required" },
                { name: "Sum", title:"Sum", type: "number", width: "30%", validate: "required" },
                { type: "control", width: "10%", editButton: false, 
                	itemTemplate: function(_, item) {
                    if(item.IsTotal)
                    	return "";
                    return jsGrid.fields.control.prototype.itemTemplate.apply(this, arguments);  
                  }
                }
            ]
        });
    body {
      background: #fff;  
    }
    
    .jsgrid-cell { 
        overflow: hidden; 
    }
    
    .jsgrid-pager { text-align: center; }
    
    .total-row {
      font-weight: bold;
    }
    
    .total-row td {
      border-top: 2px solid #efefef;
    }
<div id="jsGrid"></div>
...