The key to this problem is that Loading is centered in the visible area. If you just center the loading element in the table, it’s easy, and CSS can do that. However, if the visible area is centered, loading must be fixed, so that the top value of loading changes dynamically. You can see it clearly by looking at the following pictures.
Loading is centered in the table.
This is loading in the middle of the table. Obviously, if the table is too long, clicking query will only see the mask, not the loading. Therefore, optimization is needed, and the effect of optimization is to see loading in the visual area.
Loading is centered in the visible area of the table. Keep loading centered while scrolling.
FIG. 1
Figure 2 * * * *Copy the code
FIG. 3
As can be seen from these three figures, loading position is not always constant, but always in the middle of the visible area of the table.
How do you achieve this effect?
This uses the getBoundingClientRect() method in javascript.
Element. GetBoundingClientRect () method returns the Element size and its position relative to the viewport.
<div class="table-wrap" id="table">Form and content</div>
Copy the code
<script>
window.onload = function() {
let tableEle = document.getElementById("table");
let tableClientRect = tableEle.getBoundingClientRect();
console.log(tableClientRect);
}
</script>
GetBoundingClientRect () returns a DOMRect object. Values are as follows:
// DOMRect {x: 30, y: 160, width: 351.8374938964844, height: 2000, top: 160, left: 30,right: 381.8374938964844}
Copy the code
**getBoundingClientRect() ** Returns a value with eight attributes: left, top, right, bottom, x, y, width, height.
Left, top, right and bottom. Represents the distance between each edge of an element and the top and left side of the page. X and y represent the distance from the top left corner of the element to the top and left sides of the page. As is shown in
It’s easy to use this method to center the viewable area of the table above.
And you can try to do that yourself.
I post my code below.
<! doctypehtml>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>* {margin: 0;
padding: 0;
}
.content-wrap{
width: 100%;
overflow-y: auto;
}
.search-wrap{
width: 30%;
height: 100px;
background: #417bff;
color: #fff;
text-align: center;
margin: 30px;
}
.table-wrap{
width: 30%;
height: 2000px;
background: #985ee4;
color: #fff;
text-align: center;
margin: 30px;
position: relative;
}
.loading-mark{
width: 100%;
height: 100%;
background: rgba(0.0.0.0.2);
position: absolute;
left:0;
top: 0;
}
/* Centered relative to the table, loading may not be visible when the table is too long
/*.loading-text{ position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); } * /
.loading-text{
position: fixed;
transform: translate(-50%, -50%);
}
.footer-wrap{
width: 30%;
height: 200px;
text-align: center;
background: #314B8C;
color: #fff;
margin: 30px;
}
</style>
</head>
<body>
<div class="content-wrap" id="main">
<div class="search-wrap">Query area</div>
<div class="table-wrap" id="table">Form and content<div class="loading-mark"></div>
<div class="loading-text" id="loading">loading...</div>
</div>
<div class="footer-wrap">At the bottom of the content</div>
</div>
<script>
window.onload = function() {
let tableEle = document.getElementById("table");
let loadingEle = document.getElementById("loading");
let tableClientRect = tableEle.getBoundingClientRect();
let winH = document.documentElement.clientHeight;
document.getElementById("main").style.height = winH +'px';
//console.log(tableClientRect);
/* * With fiexD layout, loading is centered in the table viewable range, and both left and top need to be calculated. * The initial entry to the page is the state shown in Figure 1 * */
loadingEle.style.top = (winH-tableClientRect.top)/2 + tableClientRect.top + 'px';
loadingEle.style.left = tableClientRect.width/2 + tableClientRect.left + 'px';
/* * * */
document.getElementById("main").addEventListener('scroll'.function() {
tableClientRect = tableEle.getBoundingClientRect();
// The loading top value of the state in figure 1
if (tableClientRect.top>0 && tableClientRect.bottom>winH) {
loadingEle.style.top = (winH-tableClientRect.top)/2 + tableClientRect.top + 'px';
}
// Figure 2 shows the loading top value of the loading state
if (tableClientRect.top<0 && tableClientRect.bottom>winH) {
loadingEle.style.top = winH/2;
}
// Figure 3 shows the loading top value of the loading state
if (tableClientRect.top<0 && tableClientRect.bottom<winH) {
loadingEle.style.top =tableClientRect.bottom/2 + 'px'; }}); }</script>
</body>
</html>
Copy the code
The above is just one case, in a real project scenario, when you first come in and the table hasn’t requested data, the table is definitely not that long. Then the calculation is not done in the way shown in figure 1 above.
Loading’s top should be
top = (tableClientRect.bottom - tableClientRect.top)/2 + tableClientRect.top; Copy the code
It is also possible that the table is not in the viewable area when entering the page, which needs to be handled. Otherwise, you may see loading instead of the table when clicking query.
Above these situations, interested in their own complete implementation. Or have a different approach, welcome to leave a comment section, discuss together.