如何计算动态生成的html表中的行数?

时间:2013-07-11 05:07:54

标签: php

任何人都可以帮我计算使用javascript动态生成的html表中的行数吗?如果有人可以提供帮助,请告诉我,因为我试图将动态生成的行数据插入数据库

我的js代码:

<SCRIPT language="javascript">
 var count=1;
    function addRow(tableID) {
        /*if(empty(index))
        {
        var index = 0;

        }
        else
        {
        index++;
        alert(index);
        document.getElementById('cat').name = 'cat'+index;
        }*/

        var table = document.getElementById(tableID);

        var rowCount = table.rows.length;
        var count =  rowCount-1;
        alert(rowCount);

        var selectOFCat = $("#"+tableID).find('tr:eq(0)').find('.cat').get(0);
        var row = table.insertRow(rowCount);

        var colCount = table.rows[0].cells.length;

        for(var i=0; i<colCount; i++) {

            var newcell = row.insertCell(i);

            newcell.innerHTML = table.rows[0].cells[i].innerHTML;
            //alert(newcell.childNodes);
            switch(newcell.childNodes[0].type) {
                case "text":
                        newcell.childNodes[0].value = "";
                        break;
                case "checkbox":
                        newcell.childNodes[0].checked = false;
                        break;
                case "select-one":
                        newcell.childNodes[0].selectedIndex = 0;
                        break;
            }
        }

        $(table).find("tr:eq("+rowCount+")").find('.cat').attr("id","cat"+rowCount);

    }

    function deleteRow(tableID) {
        try {
        var table = document.getElementById(tableID);
        var rowCount = table.rows.length;

        for(var i=0; i<rowCount; i++) {
            var row = table.rows[i];
            var chkbox = row.cells[0].childNodes[0];
            if(null != chkbox && true == chkbox.checked) {
                if(rowCount <= 1) {
                    alert("Cannot delete all the rows.");
                    break;
                }
                table.deleteRow(i);
                rowCount--;
                i--;
            }


        }
        }catch(e) {
            alert(e);
        }
    }


  function changeSelection(value){

  var length = document.getElementById("ind").options.length;

  if(value == "All"){
  for(var i = 1;i<length;i++)
    document.getElementById("ind").options[i].selected = "selected";

  document.getElementById("ind").options[0].selected = "";
  }

}

</SCRIPT>

我的PHP代码:           

                        <table width="100%">
                            <tr>
                                <td><h5>Add your Products</h5>&nbsp;&nbsp;&nbsp;
                                </td>
                            </tr>

                           <tr><td>
                           <INPUT id="add_row" type="button" value="Add Row" onclick="addRow('dataTable')" class="btn btn-danger" name="add_row" />

<INPUT type="button" value="Delete Row" onclick="deleteRow('dataTable')" class="btn btn-danger" />
<tr>
<td bgcolor="red">
<TABLE width="100%" border="1" cellpadding="0" cellspacing="2" >

                            <tr><td width="2%">::</td><td style="width:213px;padding:5px;">Type</td><td class="srcinfo_head">Product</td><td  class="srcinfo_head">Specification</td><td class="srcinfo_head_op">Option</td><td class="srcinfo_head_src">Source</td><td  class="srcinfo_head">Frequency</td><td  class="srcinfo_head">Quantity</td><td  class="srcinfo_head">Unit</td>
                            </tr>
</table>
</td>
</tr>
<tr><td>
<TABLE id="dataTable" width="100%" border="1" cellpadding="0" cellspacing="2" style="border:#cccccc; border-width:3px; border-style:solid">

    <TR valign="top">
        <TD width="2%"><INPUT type="checkbox" name="chk" style="margin:5px;"/></TD>
        <TD class="srcinfo">
    <select  id="cat" class="cat" name="data[cat][]" size="10px" class="srcinfo_type" style ="height:77px !important;">
    <option value="">--Select a Category--
    <?= $options ?>
</select> 
        </TD>

        <TD width="15%"><?php echo tep_draw_input_field('data[productname][]','','class="srcinfo"'); ?></TD>
        <td width="15%">
        <?php echo tep_draw_textarea_field('data[specification][]', 'soft', 10,3, $HTTP_POST_VARS['specification'],'class="srcinfo"'); ?>
        </td>
        <td width="10%"><div class="srcinfo_op">
        <?php echo tep_draw_checkbox_field('data[option][]','purchase', false).'&nbsp;Purchase';
              echo tep_draw_checkbox_field('data[option][]','sell', false).'&nbsp;Sell';            ?>
        </div>

        </td>
        <td width="15%">

        <?php   $source_array = array();
                $source_array[0] = array('id' => 'All', 'text' => 'All India');
                $source_array[1] = array('id' => 'AP', 'text' => 'Andhra Pradesh');
                $source_array[2] = array('id' => 'ARP', 'text' => 'Arunachal Pradesh');
                $source_array[3] = array('id' => 'ASM', 'text' => 'Assam');
                $source_array[4] = array('id' => 'BHR', 'text' => 'Bihar');
                $source_array[5] = array('id' => 'DL', 'text' => 'Delhi');

                echo tep_draw_pull_down_menu('data[source][]', $source_array,'','class="srcinfo_source" multiple onchange="changeSelection(this.value)" id="ind"'); ?> 
        </td>
        <td width="10%">
        <?php   $frequency_array = array();
                $frequency_array[0] = array('id' => 'Yr', 'text' => 'Yearly');
                $frequency_array[1] = array('id' => 'mnth', 'text' => 'Monthly');


                echo tep_draw_pull_down_menu('data[freq][]', $frequency_array,'','class="srcinfo" style="margin-top:50px;"'); ?> 
        </td>
        <td width="8%">
        <?php echo tep_draw_input_field('data[qty][]','','class="srcinfo" style="margin-top:50px;"'); ?>

        </td>
        <td width="10%">
        <?php   $unit_array = array();
                $unit_array[0] = array('id' => 'kg', 'text' => 'kilogram');
                $unit_array[1] = array('id' => 'gr', 'text' => 'gram');
                $unit_array[2] = array('id' => 'mg', 'text' => 'milligram');


                echo tep_draw_pull_down_menu('data[unit][]', $unit_array,'','class="srcinfo" style="margin-top:50px;"'); ?> 
        </td>
    </TR>

</TABLE>       
</td></tr>
                            <tr><td>
                            <?php echo tep_draw_button(IMAGE_BUTTON_PRODINFO, 'person', null, 'primary',array( 'params' => 'name="add_pro" class="btn btn-danger" ')); ?>
                            </td></tr>
                        </table>
                        <?php

                    if(isset($_POST['add_pro']))
                        {
                        foreach($html->find('dataTable') as $table){ 
                         $all_trs = $table->find('tr');
                         $count = count($all_trs);
                         echo $count;
                         exit;
                        }
                        $src = $_POST['source'];
                        $products_source = implode(",", $src);
                        $opt = $_POST['option'];
                        $products_options = implode(",", $opt);
                        $products_array = array(
                          'products_quantity' => $products_quantity,
                          'products_date_added' => 'now()',
                          'products_source' => $products_source,
                          'products_frequency'  => $products_frequency,
                          'products_options' => $products_options,
                          'products_unit' => $products_unit,
                          'customers_id' => $customer_id
                          );

                        tep_db_perform(TABLE_PRODUCTS, $products_array);
                            $products_desc_array = array(
                          'products_name' => $products_name,
                          'products_description' => $products_description
                          );

                        tep_db_perform(TABLE_PRODUCTS_DESCRIPTION, $products_desc_array);
                        $prod_id = tep_db_insert_id();
                        $category_id_array = array('products_id' => $prod_id,
                                                    'categories_id' => $category_type_id);
                        tep_db_perform(TABLE_PRODUCTS_TO_CATEGORIES, $category_id_array);
                        $update_stage = tep_db_query("update " . TABLE_CUSTOMERS . " set customers_stage='5' where customers_id = '" . $customer_id. "'");
                        tep_redirect(tep_href_link(FILENAME_REGISTRATION_6, '', 'SSL'));
                        }

                    ?>
                    </form>

我想以动态生成的形式插入行的值。

3 个答案:

答案 0 :(得分:2)

你可以用jQuery做到这一点,试试这个

$(document).ready(function () {
    var dt = $(".TABLE_CLASS tr").length;
    alert(dt);
});

在这里检查http://jsfiddle.net/G3Dtu/

答案 1 :(得分:1)

您必须使用以下任何替代方案。

  1. simple html dom parser
  2. PHPquery
  3. snoopy
  4. 这些是PHP脚本,它们将计算表格行,并且您可以将其作为jQuery函数使用。

    / EDITED /

    我在简单的html dom解析器的帮助下给你一个例子。

     include("../simplehtml/simple_html_dom.php");
     require('../phpQuery/phpQuery/phpQuery.php');
    
    $html = file_get_html("http://".$_GET['siteName']);
    $es = $html->find('table tr');
    
    希望这会有所帮助。 PS。如果你遇到困难,我没有测试这个例子,请告诉我。

答案 2 :(得分:0)

您无法在PHP中执行此操作,您需要(Web)客户端语言。这是本机JS版本:

var rowCount = document.getElementsByTagName("table")[0].getElementsByTagName("tr").length;

如果页面上有多个表,则需要更改document.getElementsByTagName(“table”)[0]部分以获得正确的表格。

请记住,这将获取表中的所有行,包括任何标题行。

相关问题