【问题标题】:DataTables - Checkbox Selection - pagination does not retain the values of the selected checkboxesDataTables - 复选框选择 - 分页不保留所选复选框的值
【发布时间】:2017-01-27 18:20:37
【问题描述】:

我在包含两个字段的表上使用 jQuery 数据表: 一种。图像名称 湾。图片尺寸

表格的第一列(图像名称)包含我使用 html 添加的选择复选框。表中的数据是从文本文件更新的。

有一个按钮叫做make image set。用户应该能够选择多个图像并单击 make image set 按钮,这将显示一个带有所选图像名称的模式。然后用户可以输入集合名称并提交。

然而,现在的问题是,当数据表分页发生时,获取图像名称的字符串(显示在模式框上)只包含当前页面的图像名称。例如,如果我从第一页中选择 2 个图像,从第二页中选择 2 个图像,并且如果我在按下“设置图像”按钮时位于第二页,则只有最后两个图像名称显示在模式框中。

有没有一种方法可以保留复选框的选择,以确保在模态框上正确显示选择?

Javascript 代码:

        var cellsSelected="";
$(document).ready(function() {
var dataTable = $('#table_id').DataTable( {
    columnDefs: [ {
        orderable: false,
        className: 'select-checkbox',
        targets:   0
    } ],
    select: {
        style:    'multi',
        selector: 'td:first-child'
    },
    lengthMenu: [[5,10, 25, -1], [5, 10, 25, "All"]],
    pageLength: 5 
} );
          $('checkboxed').on('click', function() {
    cellsSelected = dataTable.rows({ selected: true }).data();
});

            $('#settable_id').dataTable({
    "lengthMenu": [[5,10, 25, -1], [5, 10, 25, "All"]],
        "pageLength": 5
});
} );

HTML 代码:

<table id="table_id" class="table table-responsive table-bordered table-condensed">
   <thead>
      <tr>
         <th colspan= "2" class="text-center"><span style="color:white;" aria-hidden="true"><font size="3"><strong>Image & SMU Repository </strong></font></span>
</th>
      </tr>
      <tr>
         <td class="text-center verticalalign" style="vertical-align: middle; background-color: #98b6d9;"><span style="color: black;" aria-hidden="true"><strong>Image Name</strong></span></td>
         <td class="text-center verticalalign" style="vertical-align: middle; background-color: #98b6d9;"><span style="color: black;" aria-hidden="true"><strong>File Size</strong></span></td>
      </tr>
   </thead>
   <tbody>
      <form role="form" id="myForm" method="post">
         <div class="form-group">
            <?php $first1 = ""; $second1 = "";$str = 'size';$a=0;$mylines = file('./view_images.txt');foreach($mylines as $myline){$first1 = $second1;$second1 = $myline;$str1 = (string)$second1;if($a == 1){$sizeChunks = explode(",", $second1); ?>
            <td style="vertical-align: middle;"><span style="color:black;"><a href="./Repository.php" title="MD5 = <?php echo $sizeChunks[1] ?> " class="myClass"><?php echo preg_replace('~\D~', '', $sizeChunks[0]); ?></a></span></td>
            <?php $a=0;continue;}if($first1 == "" or $first1 == "\n"){?>
            <tr>
               <td style="vertical-align: middle;" >
                  <div class="checkbox"><label><input type="checkbox" id="checkboxed" name="myCheck" value="<?php echo $second1; ?>"><span style="color:black;"><?php echo trim($second1); ?></span></label></div>
               </td>
               <?php }else{if($second1 == "\n"){?> 
            </tr>
               <?php } else{if(strcmp(trim($str1), trim($str)) == 0){ $a=1;continue;}?>
            <td style="vertical-align: middle;"><span style="color:black;"><?php echo trim($second1); ?></span></td>
            <?php }}}?>
         </div>
      </form>
   </tbody>
</table>
<div class="modal fade" id="myModal" role="dialog">
            <div class="modal-dialog">
                <div class="modal-content">
                    <div class="modal-header">
                    <button type="button" class="close" data-dismiss="modal">&times;</button>
                    <h4 class="modal-title"><span style="color:black;" aria-hidden="true"></span>Create Image Sets</h4>
                    </div>
                    <div class="modal-body" id="imgmodal">
                    </div>
                    <div class="modal-footer">

                    <button type="submit" class="btn btn-primary" id="submitimgset"><span style="color:black;" aria-hidden="true"></span>Submit</button>
                    <button type="button" class="btn btn-primary" data-dismiss="modal"><span style="color:black;" aria-hidden="true></span>Cancel</button>
</div>
                </div>
            </div>
        </div>

制作图像设置按钮 -

<button type="button" class="btn btn-primary btn-md" data-target="#myModal" id="make_image_set_id" onclick="imagesumrep()"><span style="color:black;" aria-hidden="true"></span>Make Image Set</button>

按钮的 Javascript 函数 -

function imagesumrep() {
            if(cellsSelected == ""){
                document.getElementById('imgmodal').innerHTML= "Error! <br> Please select images and try again!";

                                  $('#myModal').modal('show'); 

            }
            else{   
            document.getElementById('imgmodal').innerHTML= "<h4><strong><u>Images Selected:</u></strong></h4>" + "<strong>" + cellsSelected + "</strong> "+ "<br /><br />"+ "<h4><strong><u>Image Set Name:</u></strong></h4>" + "<input type ='text' name='setName' id='noname' size='70'><br /><br />";
            setTimeout(function(){
                                  $('#myModal').modal('show'); 
                              }, 600); 
           }
           }

请帮帮我!我对 DataTables 完全陌生!我已经按照亚当的建议进行了更改。现在,模态框根本没有打开,我收到一个错误 - “Uncaught ReferenceError: dataTable is not defined”。

我包含的脚本是:

<script src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
<script type="text/javascript" src="//cdn.datatables.net/1.10.7/js/jquery.dataTables.min.js"></script>
<script type="text/javascript" src="https://cdn.datatables.net/select/1.2.0/js/dataTables.select.min.js"></script>
<script type="text/javascript" src="//cdn.datatables.net/plug-ins/1.10.12/sorting/num-html.js"></script>
<link rel="stylesheet" type="text/css" href="bootstrap/css/bootstrap.min.css" />
<link rel="stylesheet" type="text/css" href="bootstrap/css/bootstrap-theme.css" />
<link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.7/css/jquery.dataTables.min.css" />
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/select/1.2.0/css/select.dataTables.min.css" />

<script src="bootstrap/js/bootstrap.min.js"></script>

【问题讨论】:

    标签: pagination datatables


    【解决方案1】:

    Datatables 不知道在其单元格中进行的 HTML 更改,而是仅在您使用 cell().data() 方法更新它时才知道。分页期间未显示的项目不会显示在 DOM 中,因此通过常规方式查找它们是行不通的。您必须通过 dataTables API 收集数据。

    幸运的是,他们的文档中的checkbox example 看起来基本上已经内置了您需要的内容。请注意,这使用select extension,并且您需要多选选项。但是,假设您已选择下载并包含在内,您的初始化最终会看起来像这样:

    $(document).ready(function() {
        var dataTable = $('#table_id').DataTable( {
            columnDefs: [ {
                orderable: false,
                className: 'select-checkbox',
                targets:   0
            } ],
            select: {
                style:    'multi',
                selector: 'td:first-child'
            },
            lengthMenu: [[5,10, 25, -1], [5, 10, 25, "All"]],
            pageLength: 5 
        } );
    } );
    

    当您想要获取您选择的项目时(这也是从dataTables example 中提取的):

    var dataSelected = dataTable.rows({ selected: true }).data();
    

    这将从 dataTable 中为所选的每一行返回一个数据数组,您可以在 imagesumrep() 函数中使用它。

    如果您想将其用作基础,我创建了jsfiddle 来尝试一下

    【讨论】:

    • 嗨,亚当!非常感谢你的帮助。我尝试按照您的建议实施,但我仍然犯了一些错误。我已经使用新代码更新了问题,并且还添加了包含在我的代码中的脚本。再次感谢:)
    • 嘿施鲁蒂。我忘记在我的代码中包含将保存数据表的变量。我会更新的
    • 亚当,你说“$('input').on('click', function () {...”我应该用按钮的 id 替换“input”吗?设置”需要使用这些数据?
    • 是的,ID 或其他适合您的情况的 jquery 选择器。 “输入”只是作为一个占位符来向您展示这个想法 - 对于我的快速测试,如果您单击搜索栏它会触发该功能。我懒得做按钮:)
    • 我现在更新了 jsfiddle 链接以包含一个按钮,它可能会让您更清楚。按钮只是触发代码的一种方式。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-06-03
    • 2023-03-14
    • 1970-01-01
    • 1970-01-01
    • 2012-04-23
    • 2012-05-08
    相关资源
    最近更新 更多