场景:使用服务器端处理来加载数据表网格。在标题列上设置工具提示。当鼠标悬停时,将显示工具提示。

问题:我得到了工具提示。但是发现了一个我无法解决的问题。


将鼠标悬停在标题之一上,显示工具提示


javascript - 使用Datatables.net卡住的Bootstrap 4工具提示-LMLPHP


在将鼠标悬停在标题上的同时,使用键盘将show 10条记录更改为25条记录。


javascript - 使用Datatables.net卡住的Bootstrap 4工具提示-LMLPHP


加载记录后,工具提示将停留在屏幕上。


javascript - 使用Datatables.net卡住的Bootstrap 4工具提示-LMLPHP

这是我的代码片段

var table = $('#list-of-product').DataTable({
            "processing": true,
            "serverSide": true,
            "info": true,
            "stateSave": false,
            "bFilter": false,
            "drawCallback": function (settings, json) {
                $('[data-toggle="tooltip"]').tooltip('update');
                //$("#list-of-product tbody tr > td").tooltip('hide');
            },
            "ajax": {
                "url": "@Url.Action("GetProducts", "LandingPage")",
                "type": "POST"
            },
            "language": {
                "paginate": {
                    "previous": "<<",
                    "next": ">>"
                },
                "info": "Showing _START_ to _END_ of _TOTAL_",
                "lengthMenu": "Show _MENU_",
                "search": "",
                "searchPlaceholder": "Search..."
            },
            "columns": [
                            { "data": "LineOfBusiness", "orderable": true },
                            { "data": "Discipline", "orderable": true },
                            { "data": "InventoryProgram", "orderable": true },
                            { "data": "ISBN13", "orderable": true },
                            { "data": "Title", "orderable": true },
                            { "data": "ProductID", "orderable": true },
                            {
                                data: null,
                                className: "text-center",
                                defaultContent: '<a href="#list-of-product" data-toggle="modal" data-target="#ContactAssigner"><i class="material-icons">assignment_ind</i></a>',
                                "orderable": false
                            }
            ],
            "order": [[0, "asc"]],
            createdRow: function (row, data, dataIndex) {
                $(row).find('td:eq(4)').attr('title', data["Title"]);
                $(row).find('td:eq(4)').attr('data-toggle', "tooltip");
                //$(row).find('td:eq(4)').tooltip();
            }
        });


任何建议都会有所帮助。谢谢。

最佳答案

您需要了解此页面大小更改事件,然后隐藏所有打开的工具提示。

$('#list-of-product').on('length.dt', function (e, settings, len) {
    $('[data-toggle="tooltip"]').tooltip('hide');
});


Demo on Codeply

drawCallback事件将无法很好地工作,因为它是在init上调用的,并且在每次表更新时都可能不需要隐藏所有工具提示。

10-04 22:16
查看更多