我有以下函数,它从远程 csv 文件中读取数据,并在将其显示在数据表上之前对其进行一些处理。
function loadGrid()
{
link='{{ url("thecsvfile") }}/'+$('#class-id').val();
Papa.parse(link, {
download: true,withCredentials: true,header:true,
step: function(results, parser) {
//.... process the data row by row
cleanDataForGrid(results.data);
},
complete:function()
{
table =$('#the-grid').DataTable({
responsive: true,
destroy: true,
'bProcessing': true,
paging: false,
searching: false,
info:false,
scrollCollapse:true,
'columnDefs': [{
'targets': 0,
'searchable':false,
'orderable':false,
'width':'1%',
'className': 'dt-body-center',
'render': function (data, type, full, meta){
return '<input type="checkbox" class="the_check">';
},
}],
});
updateDownloaded();
}
});
}
它目前运行良好,问题是当 CSV 文件有很多行时,加载需要很长时间,有时浏览器会挂起或崩溃。如果文件超过 X 行,我们有没有办法可以先获取行数,完全避免下载?如果我能得到这样一个只返回行数的实现。
function getRows()
{
var rowcount= Papa.parse(link, {download: false});
if(rowcount<50001) loadGrid();
}
有可能有这样的实现吗?