Как вычислить строку таблицы, у которой есть атрибут rowspan

Привет, я динамически создаю структуру таблицы. Когда я нажимаю пакет, я вставляю дочернюю строку в таблицу и добавляю значение rowspan со значением дочернего значения. Теперь мне нужно указать номер строки, в которой я использовал индекс строки, но когда есть интервал строк. Он должен считать всю строку следующим: 1 следующий номер должен быть 2. И когда я нажимаю кнопку "Удалить", мне нужно удалить всю дочернюю строку, Вот код, который я реализовал,

  var rowspans;
  var servicecount;
  var cnt;
  var ser = [];
  var refForEmployee = new Firebase("https://kekranmekrandubai.firebaseio.com/package");

  refForEmployee.on("value", function(snapshot) {
    var data = snapshot.val();
    var list = [];

    for (var key in data) {
      if (data.hasOwnProperty(key)) {
        name = data[key].image ? data[key].image : '';
        emp_name = data[key].package_name ? data[key].package_name : '';
        service = data[key].service ? data[key].service : '';
        servicecount = service.length;

        console.log("service data");
        console.log(service);
        console.log(servicecount);
        if (name.trim().length > 0) {
          list.push({
            image: name,
            emp_name: emp_name,
            services: service
          })
        }
      }
    }
    // refresh the UI
    refreshUI(list);


  });
  function refreshUI(list) {
    var lis = '';
    for (var i = 0; i < list.length; i++) {
      var empname = list[i].emp_name;
      var serc = [];
      serc = list[i].services;
      lis += '<div class="outlining"><div class="customize"><img class="employeeimages" src="' + list[i].image + '"></img><img src="img/bookingemployeeid.png" class="employee_id_display"><p class="firstname">' + list[i].emp_name + '<p class="lastname">Last name</p><p class="emps_id">1001</p><p class="arrays">' + serc + '</p></div></div>';

    };

    document.querySelector('#employee_list').innerHTML = lis;
  };
  $('body').on('click', '.employeeimages', function() {
    var name = $(this).closest('.customize').find('.firstname').text();
    var service = [];
    service = $(this).closest('.customize').find('.arrays').text();
    console.log(service);

    //var myString = "Mr. Jack Adams";
    // Create a variable to contain the array
    var mySplitResult;
    // Use the string.split function to split the string
    mySplitResult = service.split(",");
    for (i = 0; i < mySplitResult.length; i++) {

      console.log(mySplitResult[i]);
      $("#booktable").append('<tr><td><div class="maindiv"><div class="productdiv"><p class="select_product">Select Items</p></div><div class="employeediv"><p>' + mySplitResult[i] + '</p></div><div class="pricediv">Price</div></div></td></tr>');

    }
    rowspans = mySplitResult.length;
    get_values(name, table_selected_index);

    $(".select_employee_div").css("display", "none");

  });
  //booking main table
  //add row to booking table
  $(".useradd").click(function() {
    var rows = $('#booktable tr').length;
    var rowcount = rows + 1;

    $("#booktable").append('<tr><td id=' + rowcount + ' class="f">' + rowcount + '</td><td><div class="maindiv"><div class="productdiv"><p class="select_product">Select Items</p></div><div class="employeediv"><input type="button" class="select_employee" value="Select Employee"></div><div class="pricediv">Price</div><div class="actiondiv"><input type="button" value="x" class="remove"/></div></div></td></tr>');
  });

  //remove row and dynamically changing the index value of the removed row

  $("body").on("click", ".remove", function(event) {
    event.preventDefault();
    var table = 'booktable';
    var row = $(this).closest('tr');

    setTimeout(function() { // Simulating ajax
      var siblings = row.siblings();
      row.remove();
      siblings.each(function(index) {
        $(this).children().first().text(index + 1);
      });
    }, 100);
  });

  $('#booktable').on('click', '.select_employee', function() {
    $(".select_employee_div").css("display", "block");
    var indexOfTheChangedRow = $(this).closest("tr").index();
    table_selected_index = indexOfTheChangedRow;

  });

  function get_values(val, rowIndex) {
    console.log("inside get_values function");

    console.log(val);

    $('#booktable tr:eq(' + rowIndex + ')').find(".select_employee").val(val);
    $('#booktable tr:eq(' + rowIndex + ')').find(".f").attr("rowspan", rowspans + 1)

  };

Это моя структура таблицы Мне нужно

  введите описание изображения здесь

Вот демонстрация скриптов, которую я реализовал. Меня поразило изменение индекса строки и удаление действия. Скриншот Демо Пожалуйста, помогите мне составить код. Заранее благодарю вас.

Ответ 1

Вы можете использовать приведенный ниже код для удаления базы строк на rowspan и reIndex в оставшейся строке:

$('body').on('click','.remove',function(e) {
    e.preventDefault();
    var row=$(this).closest('tr');
    var rowspan=parseInt(row.children().first().attr('rowspan'));

    //remove row
    if (isNaN(rowspan)) {
        row.remove();
    } else {
        $('#booktable tr').slice(row.index(), row.index() + rowspan).remove();
    }


    //reindex
    var newIndex = 0;
    $('#booktable tr').each(function(i) {
        if ($(this).children().first().attr('id') !== undefined) {
            newIndex++;
            $(this).children().first().text(newIndex);
        }
    });
});

Ответ 2

Это, вероятно, то, что вы ищете:

$('body').on('click', '.remove', function(e){
    e.preventDefault();
    var row=$(this).closest('tr');
    row.nextAll().each(function(){
        if ($('td',this).is('[rowspan]')){
            $(this).remove()
        } else {
         row.remove(); // before exit from loop
         return false;
        }
    })
    row.remove(); //for the last TR
    $('tr').each(function(i) {
        $('td:first',this).text(i+1); //For re-index
    });
})

Или, если вам нужно удалить только первую и следующие 2 строки, это должно устранить вашу проблему:

$('body').on('click', '.remove', function(e){
    e.preventDefault();
    var row = $(this).closest('tr');
    row.add(row.nextAll().slice(0,2)).remove();
});

Благодаря answare: Jquery Next/NextAll/NextUntil с лимитом счета

Ответ 3

Вы можете использовать значение rowspan для подсчета количества строк, которые вы должны удалить $('td: first', row).attr('rowspan') - 1

http://jsfiddle.net/VixedS/af0Ljbzt/

  $('body').on('click', '.remove', function(e){
    e.preventDefault();
    var row=$(this).closest('tr');
    row.nextAll().slice(0,$('td:first',row).attr('rowspan')-1).each(function(){
      $(this).remove()
    });
    row.remove();
    $('tr:has(".f")').each(function(i) {
        $('td.f',this).text(i+1);
    });
  });