簡體   English   中英

服務器端處理 Jquery 數據表 Sharepoint

[英]Server side processing Jquery Datatables Sharepoint

我有一個 >50000 SharePoint 在線文檔庫列表正在使用下面的工作代碼呈現。 頁面加載時間接近 10-15 秒。

我嘗試實施服務器端處理以減少頁面加載時間,但沒有任何區別:

"processing": true, "serverSide": true,

<!DOCTYPE html>    
<html">    
<head>    
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/jquery-3.5.1.js"></script>        
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/jquery.dataTables.min.js"></script>     
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/moment.min.js"></script>     
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/datetime-moment.js"></script>      
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/dataTables.buttons.min.js"></script>       
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/buttons.flash.min.js"></script>            
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/jszip.min.js"></script>        
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/pdfmake.min.js"></script>      
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/vfs_fonts.js"></script>            
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/buttons.html5.min.js"></script>        
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/buttons.print.min.js"></script>        
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/dataTables.select.min.js"></script>    
    <script type="text/javascript" src="<SPO_SITE>/SiteAssets/js/dataTables.searchBuilder.min.js"></script> 
    <link rel="stylesheet" type="text/css" href="<SPO_SITE>/SiteAssets/css/jquery.dataTables.min.css">    
    <link rel="stylesheet" type="text/css" href="<SPO_SITE>/SiteAssets/css/dataTables.jqueryui.min.css">      
    <link rel="stylesheet" type="text/css" href="<SPO_SITE>/SiteAssets/css/buttons.dataTables.min.css">  
    <link rel="stylesheet" type="text/css" href="<SPO_SITE>/SiteAssets/css/select.dataTables.min.css">  
    <link rel="stylesheet" type="text/css" href="<SPO_SITE>/SiteAssets/css/searchBuilder.dataTables.min.css">  

<script>
$(document).ready(function() {loadItems();});    

function loadItems() {    
    var siteUrl = _spPageContextInfo.siteAbsoluteUrl;    
    var oDataUrl = siteUrl + "/_api/web/lists/getbytitle('LIST_NAME')/items?$top=200000&$select=Created,ATA,EncodedAbsUrl";    
    $.ajax({    
        url: oDataUrl,    
        type: "GET",    
        dataType: "json",    
        headers: {    
            "accept": "application/json;odata=verbose"    
        },    
        success: mySuccHandler,    
        error: myErrHandler    
    });    
}    
  
function mySuccHandler(data) {    
    try {    
          
        $('#table_id').DataTable({    
            "pageLength": 100,
            "dom": 'Bfrtip',
            "buttons": [ {extend: 'searchBuilder', config: {columns: [0,1,2,3,4,5,6,7],},}, 'copy', 'csv', 'pdf', {extend: 'print',exportOptions: {columns: [ 0, 1, 2, 3, 4, 5, 6, 7 ]}} ],
            "aaData": data.d.results,
            "aaSorting": [[0, "desc"]],
            "aoColumns": [  
            {    
                "mData": "Created"
            },             
            {    
                "mData": "ATA"    
            },             
            {    
                "mData": "EncodedAbsUrl",
                "mRender": function ( data, type, full )
                {return '<a href="'+data+'" target="_blank">View</a>';}             
            }
            ]    
        });    
    } catch (e) {    
        alert(e.message);    
    }    
}    
    
function myErrHandler(data, errMessage) {    
    alert("Error: " + errMessage);    
}   
</script>

</head>    
<body>    
   <div> 
    <table id="table_id" class="display" cellspacing="0" width="100%">    
        <thead>    
            <tr>    
                <th>Uploaded</th>    
                <th>ATA</th>
                <th></th>           
            </tr>    
        </thead>    
    </table>    
    </div>    
</body>    
</html>   

您必須設置后端代碼,因為服務器端意味着您必須在客戶端的每個操作(更改頁面、過濾器、搜索等)上處理服務器上的數據表行

有關更多信息,請訪問: https://datatables.net/examples/data_sources/server_side

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM