Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

how to make colspan of table footer flexible with javascript/jQuery

$(document).ready(function() {
  const header = ["Info", "Info", "Info", "Info", "Sum1", "Sum2", "Info", "Sum3", "Info", "Info", "Sum4"];
  const needles = ["Sum1", "Sum2", "Sum3", "Sum4"];

  const spans = []; // new array
  let cursor = 0; // cursor
  spans[cursor] = {
    text: '',
    colspan: 0
  };

  for (let i = 0; i < header.length; i++) {
    if (!needles.includes(header[i])) { // if not included, ++colspan
      spans[cursor].colspan++;
    } else {
      if (i !== 0) cursor++; // only needed when we have a needle
                             // in the first header element

      // here I create the new objects
      // with the text Sum1, Sum2, etc
      // and colspan=1
      spans[cursor] = {};
      spans[cursor].text = header[i];
      spans[cursor].colspan = 1;

      if (i === header.length - 1) continue; // if I am at the end 
                                             // of the header array,
                                             // skip the next block


      // if the next element in the header array is not included
      // in needles, I already create a new element with
      // colspan = 0 for the next loop.
      // If the next element is also in needles it's not necessary
      // as it will be catched by else{} block in the next loop
      if (!needles.includes(header[i + 1])) {
        cursor++;
        spans[cursor] = {};
        spans[cursor].text = '';
        spans[cursor].colspan = 0;
      }
    }
  }

  console.log(spans);

  for (const span of spans) {
    $('#testTable tfoot tr').append(`<th colspan="${span.colspan}">${span.text}</th>`);
  }
});
Comment

how to make colspan of table footer flexible with javascript/jQuery

.as-console-wrapper {
  max-height: 150px !important;
}
Comment

how to make colspan of table footer flexible with javascript/jQuery

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<table id="testTable" class="table table-bordered">
  <thead>
    <tr>
      <th>Info</th>
      <th>Info</th>
      <th>Info</th>
      <th>Info</th>
      <th>Sum</th>
      <th>Sum</th>
      <th>Info</th>
      <th>Sum</th>
      <th>Info</th>
      <th>Info</th>
      <th>Sum</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>23</td>
      <td>2</td>
      <td>Text</td>
      <td>245</td>
      <td>Text</td>
      <td>Text</td>
      <td>4</td>
    </tr>
    <tr>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>23</td>
      <td>2</td>
      <td>Text</td>
      <td>245</td>
      <td>Text</td>
      <td>Text</td>
      <td>4</td>
    </tr>
    <tr>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>23</td>
      <td>2</td>
      <td>Text</td>
      <td>245</td>
      <td>Text</td>
      <td>Text</td>
      <td>4</td>
    </tr>
    <tr>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>Text</td>
      <td>23</td>
      <td>2</td>
      <td>Text</td>
      <td>245</td>
      <td>Text</td>
      <td>Text</td>
      <td>4</td>
    </tr>
  </tbody>
  <tfoot>
    <tr>

    </tr>
  </tfoot>
</table>
Comment

PREVIOUS NEXT
Code Example
Javascript :: Undefined value document.getElementById 
Javascript :: Extract and convert from JSON by Regex 
Javascript :: remove symbols from cnpj js 
Javascript :: javascript include array value in an object property in an array map some 
Javascript :: reverse array without using another array 
Javascript :: typeorm-how-to-write-to-different-databases 
Javascript :: how to build a nested, dynamic JSON in Go 
Javascript :: express and jade, ignore render errors 
Javascript :: Transfer file to server using rsync 
Javascript :: select the value of dropdownMenu with Semantic ui react 
Javascript :: Alternative Bind() Syntax For JavaScript 
Javascript :: javascript datamatrix parser 
Javascript :: bcrypt npm 
Javascript :: queryselector undefined not working in react js 
Javascript :: short-circuit evaluation , use of || operator 
Javascript :: function listview list grud abnAlhaj 
Javascript :: how to add random color in chart in react j 
Javascript :: $faker randomElements 
Javascript :: adding amplify in index.js react native 
Javascript :: how to return data from function in javascript 
Javascript :: Joi conditional validation refer parent object 
Javascript :: NG0100: Expression has changed after it was checked 
Javascript :: animation in react stack overflow 
Javascript :: destructuring array es6 
Javascript :: verify if user input is equal to javascript 
Javascript :: angular file upload code anji 
Javascript :: react native long form keyboard awaire 
Javascript :: how to print reverse number in javascript 
Javascript :: button click event 
Javascript :: filesaver.js cdn 
ADD CONTENT
Topic
Content
Source link
Name
5+5 =