php – 使用DataTables加载Overlay
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – 使用DataTables加载Overlay,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3069字,纯文字阅读大概需要5分钟。
内容图文
![php – 使用DataTables加载Overlay](/upload/InfoBanner/zyjiaocheng/778/5d3418f7ee2a484ba5a7dea6a931965a.jpg)
我正在使用数据表并将数据从数据库收集到数组然后显示在屏幕上.这一切都很好.
如果数据大约是2000行和7列,那么它只需要几秒钟,但是如果它是10,000行和7列它可能需要大约30到40秒,所以我想添加一个灰色屏幕和显示的覆盖“加载请稍候”
我尝试过在本网站和网上找到的各种脚本和代码,但似乎都没有.我通常得到延迟,然后闪光覆盖,然后它就消失了.
任何人都可以帮忙吗?
这是我正在使用的数据表代码:
更新:这是没有数据库查询的页面.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>TEST</title>
<style type="text/css">
@import "layout_page.css";
@import "layout_table.css";
html { overflow-y: scroll; };
</style>
<link href="layout.css" rel="stylesheet" type="text/css">
<script src="jquery-1.7.2.min.js" type="text/javascript"></script>
<script src="jquery.dataTables.min.js" type="text/javascript"></script>
<script src="jquery.jeditable.js" type="text/javascript"></script>
<script src="jquery.dataTables.editable.js" type="text/javascript"></script>
</head>
<body id="dt_test">
<div id="container"><div id="layout">
<?php
if(!function_exists('json_encode'))
{
include_once('JSON.php');
$GLOBALS['JSON_OBJECT'] = new Services_JSON();
function json_encode($value)
{ return $GLOBALS['JSON_OBJECT']->encode($value); }
function json_decode($value)
{ return $GLOBALS['JSON_OBJECT']->decode($value); }
}
//
// DB QUERIES
??
$result = json_encode($data);
?>
<script type="text/javascript" charset="utf-8">
$(document).ready(function() {
$('#demo').html( '<table cellpadding="0" cellspacing="0" border="0" class="display" id="example"></table>' );
$('#example').dataTable( {
"aaData": <?php echo $result ?>,
"aoColumns": [
{ "sTitle": "Order" },
{ "sTitle": "Name" },
{ "sTitle": "Rank" },
{ "sTitle": "Number", "sClass": "center" },
{ "sTitle": "Locale", "sClass": "center" },
{ "sTitle": "Email", "sClass": "center" },
{ "sTitle": "Description", "sClass": "center" }
],
"bJQueryUI": true,
"bProcessing": true,
"bSort": false,
"bSortClasses": false,
"bDeferRender": false,
"sPaginationType": "full_numbers",
"aLengthMenu": [[10, 25, 50, 100, 250, 500, -1], [10, 25, 50, 100, 250, 500, "All"]],
"fnRowCallback": function( nRow, aData, iDisplayIndex ) {
var id = "users"+":"+aData[0];
$(nRow).attr("id",id);
return nRow;
}
} );
$('#example').dataTable().makeEditable({
sUpdateURL: "update.php",
});
} );
</script>
<div class='demo' id='demo' name='demo'></demo></div>
</div></div>
</body>
</html>
如何在其他任何内容之前添加显示的过度…然后删除一个表已准备好?
更新:
使用整个页面减去数据库查询更新了我的原始帖子.
我需要Overlay在任何数据库查询发生之前和数据表开始处理表之前显示.
谢谢
解决方法:
你可以这样做:
CSS:
#overlay {
height: 100%;
width: 100%;
position: absolute;
top: 0px;
left: 0px;
z-index: 99999;
background-color: gray;
filter: alpha(opacity=75);
-moz-opacity: 0.75;
opacity: 0.75;
display: none;
}
#overlay h2 {
position: fixed;
margin-left: 40%;
top: 40%;
}
加价:
<div id="overlay"><h2>Loading .. Please wait</h2></div>
当你想在dataTable之前显示消息/覆盖时:
$("#overlay").show();
完成初始化后,在dataTable()中回调:
$('#example').dataTable( {
...
fnInitComplete : function() {
$("#overlay").hide();
}
});
内容总结
以上是互联网集市为您收集整理的php – 使用DataTables加载Overlay全部内容,希望文章能够帮你解决php – 使用DataTables加载Overlay所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。