数据表:向所有动态加载的单元格添加工具提示

时间:2016-11-25 08:38:44

标签: jquery html css twitter-bootstrap datatables

我使用datatables并在前四列上应用了FixedColumns。列和所有单元格值都是从json动态加载的,我想应用一些功能:

1)列标题上的工具提示。我通过添加data-html="true" data-toggle="tooltip" title= ...

获得了它

2)三列标题:现在在我的列标题中我有三个值,如果可能的话我希望标题有三行,但我不知道如何将str更改为列迭代。

3)如果细胞长,则剪切细胞值。我已将此代码添加到HTML页面

<style>
#slTable td {
   white-space: nowrap; 
   text-overflow:ellipsis; 
   overflow: hidden; 
   max-width:1px;
}
</style>

4)将工具提示添加到每个单元格值以显示所有值,如果它被剪切。我在数据表初始化后迭代每个单元格,但第一行没有工具提示,页面很慢,当我去鼠标在一个值上所有单元格修改自己的大小移动所有表格。

这是实际的javascript代码:

var tableData;
var tableName='#slTable';

$(document).ready(function (){

    jQuery.ajax({
        type : "GET",
        url : "table/"+document.getElementById("hiddenIdCar").value,
        headers: {'Content-Type': 'application/json'},  
        beforeSend: function() {
            waitingModal.showPleaseWait();
        },
        success: function(data,status,xhr){
            //No exception occurred
            if(data.success){
                tableData = data.result;
                $.each(tableData.columns, function (k, colObj) {
                    //check if parnName is not empty
                    if (colObj.parName)
                        var str = '<th data-html="true" data-toggle="tooltip" title="<b>NAME</b>:'+ colObj.parName+'<br><b>DESCRIPTION</b>:' + colObj.description + '<br><b>NOTE</b>: ' + colObj.note + '"></i>' + colObj.parName + '</th>';
                    else
                        var str = '<th data-html="true" data-toggle="tooltip" title="<b>DESCRIPTION</b>:'+colObj.description+'<br><b>NOTE</b>: ' + colObj.note + '"></i>' + colObj.description + '</th>';
                    $(str).appendTo(tableName+'>thead>tr');
                });
            } else {
                waitingModal.hidePleaseWait();
                notifyMessage(data.result, 'error');
            }
        },
        error: function(xhr,status,e){
            window.location.href = "/500";
        }
    }).complete(function() {
        //initialize datatable
        if ( ! $.fn.DataTable.isDataTable( tableName ) ) {
            var slTable = $(tableName).DataTable({
                scrollCollapse: true,
                scrollX:        true,
                scrollY:        '60vh',
                paging:         false,
                "data": tableData.data,
                "columns": tableData.columns,
                fixedColumns:   {
                    leftColumns: 4
                },
                "initComplete": function(settings){
                    $('[data-toggle="tooltip"]').tooltip({
                        container: 'body'
                    }); 
                    //add timeout because otherwise user could see a too fast waiting modal
                    setTimeout(function(){
                        waitingModal.hidePleaseWait();
                    }, 1000);       
                } 
            });
        }
        else {
            slTable.ajax.url("table/"+document.getElementById("hiddenIdCar").value).load();
        }

        //TOOLTIP test cell
        $(tableName+ ' tbody td').each( function (k, cellObj){
            this.setAttribute( 'title', cellObj.innerText );
            this.setAttribute( 'data-toggle', "tooltip" );
        });
        /* Apply the tooltips */
        slTable.$('td').tooltip( {
//          "delay": 0,
//          "track": true,
//          "fade": 250
        } );
    });     
});

该表有300行和200列(可能我必须切换到服务器端处理)。 你能帮助我吗?感谢

更新1: 我已将所有工具提示代码移动到initComplete中并且它可以正常工作

"initComplete": function(settings){
                //TOOLTIP test cell
                $(tableName+ ' tbody td').each( function (k, cellObj){
                    this.setAttribute( 'title', cellObj.innerText );
                    this.setAttribute( 'data-toggle', "tooltip" );
                });
                $('[data-toggle="tooltip"]').tooltip({
                    container: 'body'
                }); 
                //add timeout because otherwise user could see a too fast waiting modal
                setTimeout(function(){
                    waitingModal.hidePleaseWait();
                }, 1000);       
            } 

有关三个行标题的任何想法吗?

2 个答案:

答案 0 :(得分:1)

如果您运行此代码,它将自动激活所有工具提示。你没有&#39;不得不担心引用特定的。

$(function () {
  $('[data-toggle="tooltip"]').tooltip()
})

答案 1 :(得分:1)

问题是您要尝试初始化ajax DataTables回调中的tooltips.complete。有可能你的success方法中的逻辑还没有完成,你试图在完整的回调中应用Datatable和工具提示。我建议你将complete回调中的所有逻辑包装到一个函数中,并在$.each(tableData.columns循环后调用该函数。