- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个应用程序,该应用程序从数据库中获取许多记录并将它们呈现到表中。这是通过 AJAX 调用完成的,并将它们附加到已有结果的末尾。
记录数在本例中是变量,可以是 10 或 20,000,具体取决于搜索条件返回的内容。
现在,首先要做的事情。我知道页面上有 20,000 条记录并不明智,但这是允许从此页面查看、修改或标记所有记录的要求。
对 PHP 页面的 AJAX 调用很好,而且似乎运行得很快。然而,瓶颈在于一旦通过 AJAX 接收到数据,就将其附加到 DOM。
在下面的代码中,您将看到创建表行并将其返回到 AJAX 调用的主函数。
/*
Create Table Rows
*/
function createTableRows($dashboardID, $type){
// Timer
$start = microtime(true);
// Dashboard
$dashboardID = $_REQUEST['dashboardID'];
$objDB = new DB;
$objData = $objDB
-> setStoredProc('RenderDashboard')
-> setParam('dashboardID', $dashboardID)
-> setParam('limit', $_REQUEST['limit'])
-> setParam('offset', $_REQUEST['offset'])
-> setParam('actor', '1234')
-> execStoredProc()
-> parseXML();
// Fetch other data
$markupData = fetchMarkup($dashboardID);
$exportFields = fetchExportFields($dashboardID);
$ignore = Array('identifierQID', 'identifierNTID');
// Vars
$outputArray = Array();
$recordCount = 0;
$i = 0;
// Loop over our data
foreach($objData->data as $r){
$outputArray[$i++] = '<tr data-qid="'.$r->identifierQID.'" class="primaryValue ' . searchMarkup($markupData, $r->identifierQID) . '">';
// Loop over our fields
foreach($r as $key => $value){
// Vars
$fieldID = str_replace('_', '', $key);
// Don't include our identifier columns
if(!in_array($fieldID, $ignore)){
$outputArray[$i++] = '<td data-tableexport-display="always" class="small' . ($exportFields ? (in_array($fieldID, $exportFields) ? ' hidden' : '') : '') . '">' . formatFieldData($fieldID, $value) . '</td>';
}
}
// Notes always come last
$outputArray[$i++] = '<td data-tableexport-display="always" class="notesTD allowContext hidden"></td>';
$outputArray[$i++] = '</tr>';
$recordCount++;
}
// Join our rows array and return it
$end = microtime(true);
$timer = number_format($end - $start, 2);
return array(join("",$outputArray), $recordCount, $timer);
}
// This is what gets passed back to our AJAX call on the UI
echo createTableRows($dashboardID)[0];
这是处理收到的响应的 Javascript。
// Given data, create our table rows
function createRows(data) {
// Update Progress Bar
$('[name=progressDiv]').show();
// Append the results to the DOM
/* THIS IS WHAT IS KILLING THE SPEED!!!!*/
$('[name=resultsTable]').append(data);
// If our total number of records exceeds the threshold, we will be using the progress bar for the status
if (totalRecords > maxThreshold) {
$('[name=resultsProgress]').attr('aria-valuenow', currentPage / totalPages * 100)
.css('width', currentPage / totalPages * 100 + '%')
.text((currentPage < totalPages ? recordsPerPage * currentPage + ' of ' + totalRecords + ' records loaded' : 'Loaded ' + totalRecords + ' records!'));
} else {
// Loaded all records in one shot, update progress bar
$('[name=resultsProgress]').attr('aria-valuenow', 100)
.css('width', '100%')
.text('Loaded ' + totalRecords + ' records!')
.removeClass('active');
}
// Do we have more data to load?
if (currentPage < totalPages && totalRecords > maxThreshold) {
// Allow a little time for the progress to update before locking up
setTimeout(function(){
fetchMore();
}, 100);
}
// After the table has been appended to the DOM, run clean up to enable any additional functionality
cleanUp();
}
问题:
问题是 APPEND
锁定了浏览器并导致浏览器在追加完成之前无响应。我已经将其分解,因此它将批量获取数据,但这不是问题,它处理响应中的行。
问题:
有没有办法批量处理结果并附加结果而不锁定浏览器?它本身的响应只是一堆 TR
,附加到我的表的 TBODY
中。
我最后的手段是对结果进行分页。如果我能解决这个瓶颈,我就可以说服他们对更大的数据集进行分页。
我想我正在寻找一种方法,要么以更好的格式返回结果以进行附加,要么分解响应并在另一个 AJAX 调用获取更多数据进行处理时将其批量附加。
想法?
最佳答案
您可以使用 Javascript 表格组件来处理大量 JSON 数据的显示。例如:https://clusterize.js.org/
关于javascript - AJAX - 附加数据时大响应锁定浏览器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41347596/
我对 Java 并发性比较陌生(还没有阅读 JCIP,但它在我的列表中!)并且我有一个关于锁定行为的问题。具体来说,Java 是锁定对象的引用,还是锁定对象本身? 代码示例(不是 sscce,因为我不
我的团队使用 TortoiseSVN 编写版本控制代码。有时,有人使用“获取锁定”选项。是否有可能看到解决方案中的锁? 最佳答案 http://tortoisesvn.net/docs/nightly
我在使用 SVN 时遇到了一个小问题。 当我跑 svn stat我明白了: ~ some/dir 当我跑 svn commit -m "test"我明白了:svn: working copy
我启用了 jenkins 安全性,认为它会提示我创建一个帐户。我尝试在 c:/program files/jenkins 中删除和编辑我的 config.xml 文件,但我不确定如何在没有访问权限的情
实现与 S3 结合使用的简单锁定机制的推荐方法是什么? 我想做的例子: 通过对象 ID 获取锁 从 S3 读取对象 修改数据 将对象写入 S3 释放锁 理想情况下寻找基于云的锁定机制。我可以在本地使用
找到这个here : 一般来说,在以下任何情况下,请考虑在列上创建索引: 索引列上存在引用完整性约束,或者列。索引是避免全表锁的一种方法,否则,如果您更新父表主键,则需要,合并到父表中,或从父表中删除
在我的程序中,我将把每个“ block ”数据存储在一个单独的文件中。多个线程都会读取和写入各种文件,我想避免因未正确同步而可能出现的问题。本质上,我想要一个设置,其中每个文件的行为就好像它有自己的
我想使用此script作为资源,通过使用Windows API(重置管理器)与Go for Windows中的内容相同 到目前为止,我的代码是 Rstrtmgr := syscall.NewLazyD
这里的问题是:“这些选择中的哪一个对于线程安全选择的剧院具有最佳性能?” public static List lockList = initializeLocks(); public boolean
我有一个侧面菜单,单击图标时打开,单击页面或单击菜单上的项目时关闭。我正在尝试实现锁定,因此当单击锁定图标时,即使您单击菜单项或页面,菜单也不会关闭。 我能够将图标从锁定图标更改为解锁图标,但我在停止
使用 TRueType 字体编写 SDL 程序。我调用 TTF_Init() 来初始化 TTF 并使用 TTF_OpenFont( name, size ) 打开我的字体。 我有一个例程,可以使用以下
我正在尝试调试基于运行 FreeRTOS 的 STM32F3 uC 的应用程序。我已在应用程序的线程上下文中的随机位置手动将 PSP 设置为无效值(例如 0),希望触发 memManageFault/
我有以下 C# 代码: 1. List bandEdgeList; 2. 3. bandEdgeList = CicApplication.BandEdgeCache.Where(r
我正在用骰子制作游戏。这个想法是持有/锁定骰子。我把骰子做成按钮,这样现在就可以点击它们了。示例:我抛出一个“6”和一个“1”。我点击“6”,所以现在只会抛出“1”。 我对这个有点迷失了,我需要创建
我正在使用以下代码下载约 200mb 的播客并将其写入文档目录: var podcastRequest = NSURLRequest(URL: audioUrl) NSURLConnection.se
下面的类 DoStuff 启动一个线程并同步以保护监听器对象在 null 时不被访问。 现在,当从外部访问 DoStuff 类函数 setOnProgressListener() 时,我遇到了问题,因
我正在编写一个使用巨大背景 Canvas 的网站。我试图锁定浏览器调整大小处理程序以避免滚动问题(背景越界等) 这是我第一次做一个完整的后台网站。任何有关优化的建议(png 大小 580.72 KB
我是 C# 和线程的新手,我有这个问题要解决: 我有一个处理一些数据的线程,它会不时(必要时)触发我在启动线程之前设置的事件方法 (DataProcessor)。该线程位于专有 dll 中。所以我不能
我正在使用相机,我使用的是文档中给出的完全相同的示例: http://developer.android.com/resources/samples/ApiDemos/src/com/example/
我有几个座位可供用户预订。同一时间,只有一个用户可以参与预订过程,这样同一个座位就不会被多个用户预订。在我的 Java 代码中,我使用了“synchronized”关键字来完成它。这行得通。 但是,现
我是一名优秀的程序员,十分优秀!