如何通过单击数据属性将水平滚动 table 滚动到特定位置?
How can I scroll my horizontally scrollable table to a certain position by click on data attribute?
通过单击左侧的某个日期(例如 2018-04-03
),我希望我的 table 滚动到该位置(在这种情况下 Apr 03
)。我的方法没有奏效。这意味着,只有当我点击 "Project 1" 时,我的 table 才会滚动到某个位置。
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).appendTo('#table-scroll').addClass('clone');
});
var side_width = $( ".fixed-side" ).width()+262;
$("body").on("click", function(e) {
// the coordinate you clicked
var x = e.clientX
var y = e.clientY
// all th.fixed-side in cloned table (include thead and tbody)
var fixedSide = $('table.clone th.fixed-side')
// calculate the height of cloned table's tbody
// var tableHeight = fixedSide.get(0).offsetHeight * fixedSide.length - 1;
// only first th in tbody
var tableHeight = fixedSide.get(0).offsetHeight;
// th's width
var offsetWidth = fixedSide.get(0).offsetWidth;
// calculate offsetTop and offsetLeft from body
var offset = getOffset(fixedSide.get(0))
// skip thead's th
offset.Top += fixedSide.get(0).offsetHeight;
// check if click inside the range
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top && y <= offset.Top + tableHeight)
if (inRange) {
var date = $(e.target).closest('tr').find("[data-date]").data("date");
var result = $('[data-date="'+date+'"]').offset().left;
$('.table-wrap').scrollLeft(result - side_width);
alert("successfull scrolled to "+date);
}
});
function getOffset(element) {
var offsetTop = 0;
var offsetLeft = 0;
do {
offsetTop += element.offsetTop;
offsetLeft += element.offsetLeft;
} while (element = element.offsetParent);
var offset = {
Left: offsetLeft,
Top: offsetTop,
}
return offset;
}
.table-scroll {
position: relative;
margin: auto;
overflow: hidden;
}
.table-wrap {
width: 100%;
overflow: auto;
}
.table-scroll table {
width: 100%;
margin: auto;
border-collapse: separate;
border-spacing: 0;
}
.table-scroll th,
.table-scroll td {
padding: 5px 10px;
white-space: nowrap;
vertical-align: top;
}
.clone {
position: absolute;
top: 0;
left: 0;
pointer-events: none;
}
.clone th,
.clone td {
visibility: hidden
}
.clone td,
.clone th {
border-color: transparent
}
.clone tbody th {
visibility: visible;
}
.clone .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone thead,
.clone tfoot {
background: transparent;
}
.gantt-h {
font-weight: normal;
color: #b0b0b0;
border-right: 2px solid #f4f4f4;
}
.last {
border-right: 2px solid #f4f4f4;
}
.gantt td {
border-right: 2px solid #f4f4f4;
}
.today {
background-color: pink;
width: 100px;
cursor: pointer
}
.fixed-side{
cursor:pointer
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css">
<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div id="table-scroll" class="table-scroll">
<div class="table-wrap">
<table class="main-table table gantt">
<thead>
<tr>
<th class="fixed-side" scope="col" class="left-h" style="border-bottom:2px solid #f4f4f4;color:#b0b0b0">Task</th>
<th scope="col" class="gantt-h" style="font-weight:normal;color:#b0b0b0;">30 Mar</th>
<th scope="col" class="gantt-h">31 Mar</th>
<th scope="col" class="gantt-h">01 Apr</th>
<th scope="col" class="gantt-h">02 Apr</th>
<th scope="col" class="gantt-h">03 Apr</th>
<th scope="col" class="gantt-h">04 Apr</th>
<th scope="col" class="gantt-h">05 Apr</th>
<th scope="col" class="gantt-h">06 Apr</th>
<th scope="col" class="gantt-h">07 Apr</th>
<th scope="col" class="gantt-h">08 Apr</th>
<th scope="col" class="gantt-h">09 Apr</th>
<th scope="col" class="gantt-h">10 Apr</th>
<th scope="col" class="gantt-h">11 Apr</th>
<th scope="col" class="gantt-h">12 Apr</th>
<th scope="col" class="gantt-h">13 Apr</th>
<th scope="col" class="gantt-h">14 Apr</th>
<th scope="col" class="gantt-h">15 Apr</th>
</tr>
</thead>
<tbody>
<tr>
<th data-name="Projekt 1" class="fixed-side project"><i class="fa fa-folder-open-o" style="color:#9e9e9e"></i> Projekt 1</th>
<td data-row="1" data-date="2018-03-30"></td>
<td data-row="1" data-date="2018-03-31"></td>
<td data-row="1" data-date="2018-04-01"></td>
<td data-row="1" data-date="2018-04-02"></td>
<td data-row="1" data-date="2018-04-03"></td>
<td data-row="1" data-date="2018-04-04"></td>
<td data-row="1" data-date="2018-04-05"></td>
<td data-row="1" data-date="2018-04-06"></td>
<td data-row="1" data-date="2018-04-07"></td>
<td data-row="1" data-date="2018-04-08"></td>
<td data-row="1" data-date="2018-04-09"></td>
<td data-row="1" data-date="2018-04-10"></td>
<td data-row="1" data-date="2018-04-11"></td>
<td data-row="1" data-date="2018-04-12"></td>
<td data-row="1" data-date="2018-04-13"></td>
<td data-row="1" data-date="2018-04-14"></td>
<td data-row="1" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="2" data-date="2018-03-31"></td>
<td data-row="2" data-date="2018-04-01"></td>
<td data-row="2" data-date="2018-04-02"></td>
<td data-row="2" data-date="2018-04-03"></td>
<td data-row="2" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="2" data-date="2018-04-06"></td>
<td data-row="2" data-date="2018-04-07"></td>
<td data-row="2" data-date="2018-04-08"></td>
<td data-row="2" data-date="2018-04-09"></td>
<td data-row="2" data-date="2018-04-10"></td>
<td data-row="2" data-date="2018-04-11"></td>
<td data-row="2" data-date="2018-04-12"></td>
<td data-row="2" data-date="2018-04-13"></td>
<td data-row="2" data-date="2018-04-14"></td>
<td data-row="2" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-03" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-03</th>
<td data-row="3" data-date="2018-03-30"></td>
<td data-row="3" data-date="2018-03-31"></td>
<td data-row="3" data-date="2018-04-01"></td>
<td data-row="3" data-date="2018-04-02"></td>
<td data-row="3" data-date="2018-04-03"></td>
<td data-row="3" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="3" data-date="2018-04-06"></td>
<td data-row="3" data-date="2018-04-07"></td>
<td data-row="3" data-date="2018-04-08"></td>
<td data-row="3" data-date="2018-04-09"></td>
<td data-row="3" data-date="2018-04-10"></td>
<td data-row="3" data-date="2018-04-11"></td>
<td data-row="3" data-date="2018-04-12"></td>
<td data-row="3" data-date="2018-04-13"></td>
<td data-row="3" data-date="2018-04-14"></td>
<td data-row="3" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-01" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-01</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="4" data-date="2018-03-31"></td>
<td data-row="4" data-date="2018-04-01"></td>
<td data-row="4" data-date="2018-04-02"></td>
<td data-row="4" data-date="2018-04-03"></td>
<td data-row="4" data-date="2018-04-04"></td>
<td data-row="4" data-date="2018-04-05"></td>
<td data-row="4" data-date="2018-04-06"></td>
<td data-row="4" data-date="2018-04-07"></td>
<td data-row="4" data-date="2018-04-08"></td>
<td data-row="4" data-date="2018-04-09"></td>
<td data-row="4" data-date="2018-04-10"></td>
<td data-row="4" data-date="2018-04-11"></td>
<td data-row="4" data-date="2018-04-12"></td>
<td data-row="4" data-date="2018-04-13"></td>
<td data-row="4" data-date="2018-04-14"></td>
<td data-row="4" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-04" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-04</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="5" data-date="2018-03-31"></td>
<td data-row="5" data-date="2018-04-01"></td>
<td data-row="5" data-date="2018-04-02"></td>
<td data-row="5" data-date="2018-04-03"></td>
<td data-row="5" data-date="2018-04-04"></td>
<td data-row="5" data-date="2018-04-05"></td>
<td data-row="5" data-date="2018-04-06"></td>
<td data-row="5" data-date="2018-04-07"></td>
<td data-row="5" data-date="2018-04-08"></td>
<td data-row="5" data-date="2018-04-09"></td>
<td data-row="5" data-date="2018-04-10"></td>
<td data-row="5" data-date="2018-04-11"></td>
<td data-row="5" data-date="2018-04-12"></td>
<td data-row="5" data-date="2018-04-13"></td>
<td data-row="5" data-date="2018-04-14"></td>
<td data-row="5" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="6" data-date="2018-03-30"></td>
<td data-row="6" data-date="2018-03-31"></td>
<td data-row="6" data-date="2018-04-01"></td>
<td data-row="6" data-date="2018-04-02"></td>
<td data-row="6" data-date="2018-04-03"></td>
<td data-row="6" data-date="2018-04-04"></td>
<td data-row="6" data-date="2018-04-05"></td>
<td data-row="6" data-date="2018-04-06"></td>
<td data-row="6" data-date="2018-04-07"></td>
<td data-row="6" data-date="2018-04-08"></td>
<td data-row="6" data-date="2018-04-09"></td>
<td data-row="6" data-date="2018-04-10"></td>
<td data-row="6" data-date="2018-04-11"></td>
<td data-row="6" data-date="2018-04-12"></td>
<td data-row="6" data-date="2018-04-13"></td>
<td data-row="6" data-date="2018-04-14"></td>
<td data-row="6" data-date="2018-04-15"></td>
</tr>
</tbody>
</table>
</div>
</div>
var tableHeight
是问题所在。您已将其设置为 tbody
中第一个 th
的高度,这正是您预期的功能正在发挥作用的地方,即 Projekt 1。(似乎您错过了更新它,因为您已正式发表评论最重要的是说明相同)。
因此,您的点击次数未被评估为 inRange
。您可以通过更改
来确认
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top && y <= offset.Top + tableHeight);`
到
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top);
希望这对您有所帮助,您可以从此处根据您的要求调整 tableHeight
。另外,@Keith 的建议很准确。
编辑:
检查此 fiddle。根据上述建议,对左栏中日期的点击被评估为 inRange
。水平滚动似乎也有效(您可以点击 04-04-2018 然后点击 02-04-2018 确认)。
您不需要所有这些 javascript,只需将其缩小为:
https://jsfiddle.net/hgbL1h2y/
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).insertBefore('.main-table').addClass('clone');
});
$(".gantt tbody th, .fixed-side").on("click", function(e) {
var row_num = parseInt( $(this).parent().index() ) + 1;
var getWidth = $('.gantt td').outerWidth();
$('.table-wrap').scrollLeft(0 + (getWidth * row_num));
});
setTimeout(function (){
$('.clone').find('tr td').remove();
}, 500)
也改了一些css:
.clone {
position: absolute;
top: 10px;
left: 10px;
position: fixed;
}
.gantt .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone tbody th{
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
}
并添加了边距:
<table class="main-table table gantt" style="margin-left: -10px;">
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).insertBefore('.main-table').addClass('clone');
});
$(".gantt tbody th, .fixed-side").on("click", function(e) {
var row_num = parseInt( $(this).parent().index() ) + 1;
var getWidth = $('.gantt td').outerWidth();
$('.table-wrap').scrollLeft(0 + (getWidth * row_num));
});
setTimeout(function (){
$('.clone').find('tr td').remove();
}, 500)
.table-scroll {
position: relative;
margin: auto;
overflow: hidden;
}
.table-wrap {
width: 100%;
overflow: auto;
}
.table-scroll table {
width: 100%;
margin: auto;
border-collapse: separate;
border-spacing: 0;
}
.table-scroll th,
.table-scroll td {
padding: 5px 10px;
white-space: nowrap;
vertical-align: top;
}
.clone {
position: absolute;
top: 10px;
left: 10px;
position: fixed;
}
.gantt .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone th,
.clone td {
visibility: hidden
}
.clone td,
.clone th {
border-color: transparent
}
.clone tbody th{
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
}
.clone .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone thead,
.clone tfoot {
background: transparent;
}
.gantt-h {
font-weight: normal;
color: #b0b0b0;
border-right: 2px solid #f4f4f4;
}
.last {
border-right: 2px solid #f4f4f4;
}
.gantt td {
border-right: 2px solid #f4f4f4;
}
.today {
background-color: pink;
width: 100px;
cursor: pointer
}
.fixed-side{
cursor:pointer
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css">
<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div id="table-scroll" class="table-scroll">
<div class="table-wrap">
<table class="main-table table gantt" style="margin-left: -10px;">
<thead>
<tr>
<th class="fixed-side" scope="col" class="left-h" style="border-bottom:2px solid #f4f4f4;color:#b0b0b0">Task</th>
<th scope="col" class="gantt-h" style="font-weight:normal;color:#b0b0b0;">30 Mar</th>
<th scope="col" class="gantt-h">31 Mar</th>
<th scope="col" class="gantt-h">01 Apr</th>
<th scope="col" class="gantt-h">02 Apr</th>
<th scope="col" class="gantt-h">03 Apr</th>
<th scope="col" class="gantt-h">04 Apr</th>
<th scope="col" class="gantt-h">05 Apr</th>
<th scope="col" class="gantt-h">06 Apr</th>
<th scope="col" class="gantt-h">07 Apr</th>
<th scope="col" class="gantt-h">08 Apr</th>
<th scope="col" class="gantt-h">09 Apr</th>
<th scope="col" class="gantt-h">10 Apr</th>
<th scope="col" class="gantt-h">11 Apr</th>
<th scope="col" class="gantt-h">12 Apr</th>
<th scope="col" class="gantt-h">13 Apr</th>
<th scope="col" class="gantt-h">14 Apr</th>
<th scope="col" class="gantt-h">15 Apr</th>
</tr>
</thead>
<tbody>
<tr>
<th data-name="Projekt 1" class="fixed-side project"><i class="fa fa-folder-open-o" style="color:#9e9e9e"></i> Projekt 1</th>
<td data-row="1" data-date="2018-03-30"></td>
<td data-row="1" data-date="2018-03-31"></td>
<td data-row="1" data-date="2018-04-01"></td>
<td data-row="1" data-date="2018-04-02"></td>
<td data-row="1" data-date="2018-04-03"></td>
<td data-row="1" data-date="2018-04-04"></td>
<td data-row="1" data-date="2018-04-05"></td>
<td data-row="1" data-date="2018-04-06"></td>
<td data-row="1" data-date="2018-04-07"></td>
<td data-row="1" data-date="2018-04-08"></td>
<td data-row="1" data-date="2018-04-09"></td>
<td data-row="1" data-date="2018-04-10"></td>
<td data-row="1" data-date="2018-04-11"></td>
<td data-row="1" data-date="2018-04-12"></td>
<td data-row="1" data-date="2018-04-13"></td>
<td data-row="1" data-date="2018-04-14"></td>
<td data-row="1" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="2" data-date="2018-03-31"></td>
<td data-row="2" data-date="2018-04-01"></td>
<td data-row="2" data-date="2018-04-02"></td>
<td data-row="2" data-date="2018-04-03"></td>
<td data-row="2" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="2" data-date="2018-04-06"></td>
<td data-row="2" data-date="2018-04-07"></td>
<td data-row="2" data-date="2018-04-08"></td>
<td data-row="2" data-date="2018-04-09"></td>
<td data-row="2" data-date="2018-04-10"></td>
<td data-row="2" data-date="2018-04-11"></td>
<td data-row="2" data-date="2018-04-12"></td>
<td data-row="2" data-date="2018-04-13"></td>
<td data-row="2" data-date="2018-04-14"></td>
<td data-row="2" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-03" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-03</th>
<td data-row="3" data-date="2018-03-30"></td>
<td data-row="3" data-date="2018-03-31"></td>
<td data-row="3" data-date="2018-04-01"></td>
<td data-row="3" data-date="2018-04-02"></td>
<td data-row="3" data-date="2018-04-03"></td>
<td data-row="3" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="3" data-date="2018-04-06"></td>
<td data-row="3" data-date="2018-04-07"></td>
<td data-row="3" data-date="2018-04-08"></td>
<td data-row="3" data-date="2018-04-09"></td>
<td data-row="3" data-date="2018-04-10"></td>
<td data-row="3" data-date="2018-04-11"></td>
<td data-row="3" data-date="2018-04-12"></td>
<td data-row="3" data-date="2018-04-13"></td>
<td data-row="3" data-date="2018-04-14"></td>
<td data-row="3" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-01" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-01</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="4" data-date="2018-03-31"></td>
<td data-row="4" data-date="2018-04-01"></td>
<td data-row="4" data-date="2018-04-02"></td>
<td data-row="4" data-date="2018-04-03"></td>
<td data-row="4" data-date="2018-04-04"></td>
<td data-row="4" data-date="2018-04-05"></td>
<td data-row="4" data-date="2018-04-06"></td>
<td data-row="4" data-date="2018-04-07"></td>
<td data-row="4" data-date="2018-04-08"></td>
<td data-row="4" data-date="2018-04-09"></td>
<td data-row="4" data-date="2018-04-10"></td>
<td data-row="4" data-date="2018-04-11"></td>
<td data-row="4" data-date="2018-04-12"></td>
<td data-row="4" data-date="2018-04-13"></td>
<td data-row="4" data-date="2018-04-14"></td>
<td data-row="4" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-04" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-04</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="5" data-date="2018-03-31"></td>
<td data-row="5" data-date="2018-04-01"></td>
<td data-row="5" data-date="2018-04-02"></td>
<td data-row="5" data-date="2018-04-03"></td>
<td data-row="5" data-date="2018-04-04"></td>
<td data-row="5" data-date="2018-04-05"></td>
<td data-row="5" data-date="2018-04-06"></td>
<td data-row="5" data-date="2018-04-07"></td>
<td data-row="5" data-date="2018-04-08"></td>
<td data-row="5" data-date="2018-04-09"></td>
<td data-row="5" data-date="2018-04-10"></td>
<td data-row="5" data-date="2018-04-11"></td>
<td data-row="5" data-date="2018-04-12"></td>
<td data-row="5" data-date="2018-04-13"></td>
<td data-row="5" data-date="2018-04-14"></td>
<td data-row="5" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="6" data-date="2018-03-30"></td>
<td data-row="6" data-date="2018-03-31"></td>
<td data-row="6" data-date="2018-04-01"></td>
<td data-row="6" data-date="2018-04-02"></td>
<td data-row="6" data-date="2018-04-03"></td>
<td data-row="6" data-date="2018-04-04"></td>
<td data-row="6" data-date="2018-04-05"></td>
<td data-row="6" data-date="2018-04-06"></td>
<td data-row="6" data-date="2018-04-07"></td>
<td data-row="6" data-date="2018-04-08"></td>
<td data-row="6" data-date="2018-04-09"></td>
<td data-row="6" data-date="2018-04-10"></td>
<td data-row="6" data-date="2018-04-11"></td>
<td data-row="6" data-date="2018-04-12"></td>
<td data-row="6" data-date="2018-04-13"></td>
<td data-row="6" data-date="2018-04-14"></td>
<td data-row="6" data-date="2018-04-15"></td>
</tr>
</tbody>
</table>
</div>
</div>
通过单击左侧的某个日期(例如 2018-04-03
),我希望我的 table 滚动到该位置(在这种情况下 Apr 03
)。我的方法没有奏效。这意味着,只有当我点击 "Project 1" 时,我的 table 才会滚动到某个位置。
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).appendTo('#table-scroll').addClass('clone');
});
var side_width = $( ".fixed-side" ).width()+262;
$("body").on("click", function(e) {
// the coordinate you clicked
var x = e.clientX
var y = e.clientY
// all th.fixed-side in cloned table (include thead and tbody)
var fixedSide = $('table.clone th.fixed-side')
// calculate the height of cloned table's tbody
// var tableHeight = fixedSide.get(0).offsetHeight * fixedSide.length - 1;
// only first th in tbody
var tableHeight = fixedSide.get(0).offsetHeight;
// th's width
var offsetWidth = fixedSide.get(0).offsetWidth;
// calculate offsetTop and offsetLeft from body
var offset = getOffset(fixedSide.get(0))
// skip thead's th
offset.Top += fixedSide.get(0).offsetHeight;
// check if click inside the range
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top && y <= offset.Top + tableHeight)
if (inRange) {
var date = $(e.target).closest('tr').find("[data-date]").data("date");
var result = $('[data-date="'+date+'"]').offset().left;
$('.table-wrap').scrollLeft(result - side_width);
alert("successfull scrolled to "+date);
}
});
function getOffset(element) {
var offsetTop = 0;
var offsetLeft = 0;
do {
offsetTop += element.offsetTop;
offsetLeft += element.offsetLeft;
} while (element = element.offsetParent);
var offset = {
Left: offsetLeft,
Top: offsetTop,
}
return offset;
}
.table-scroll {
position: relative;
margin: auto;
overflow: hidden;
}
.table-wrap {
width: 100%;
overflow: auto;
}
.table-scroll table {
width: 100%;
margin: auto;
border-collapse: separate;
border-spacing: 0;
}
.table-scroll th,
.table-scroll td {
padding: 5px 10px;
white-space: nowrap;
vertical-align: top;
}
.clone {
position: absolute;
top: 0;
left: 0;
pointer-events: none;
}
.clone th,
.clone td {
visibility: hidden
}
.clone td,
.clone th {
border-color: transparent
}
.clone tbody th {
visibility: visible;
}
.clone .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone thead,
.clone tfoot {
background: transparent;
}
.gantt-h {
font-weight: normal;
color: #b0b0b0;
border-right: 2px solid #f4f4f4;
}
.last {
border-right: 2px solid #f4f4f4;
}
.gantt td {
border-right: 2px solid #f4f4f4;
}
.today {
background-color: pink;
width: 100px;
cursor: pointer
}
.fixed-side{
cursor:pointer
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css">
<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div id="table-scroll" class="table-scroll">
<div class="table-wrap">
<table class="main-table table gantt">
<thead>
<tr>
<th class="fixed-side" scope="col" class="left-h" style="border-bottom:2px solid #f4f4f4;color:#b0b0b0">Task</th>
<th scope="col" class="gantt-h" style="font-weight:normal;color:#b0b0b0;">30 Mar</th>
<th scope="col" class="gantt-h">31 Mar</th>
<th scope="col" class="gantt-h">01 Apr</th>
<th scope="col" class="gantt-h">02 Apr</th>
<th scope="col" class="gantt-h">03 Apr</th>
<th scope="col" class="gantt-h">04 Apr</th>
<th scope="col" class="gantt-h">05 Apr</th>
<th scope="col" class="gantt-h">06 Apr</th>
<th scope="col" class="gantt-h">07 Apr</th>
<th scope="col" class="gantt-h">08 Apr</th>
<th scope="col" class="gantt-h">09 Apr</th>
<th scope="col" class="gantt-h">10 Apr</th>
<th scope="col" class="gantt-h">11 Apr</th>
<th scope="col" class="gantt-h">12 Apr</th>
<th scope="col" class="gantt-h">13 Apr</th>
<th scope="col" class="gantt-h">14 Apr</th>
<th scope="col" class="gantt-h">15 Apr</th>
</tr>
</thead>
<tbody>
<tr>
<th data-name="Projekt 1" class="fixed-side project"><i class="fa fa-folder-open-o" style="color:#9e9e9e"></i> Projekt 1</th>
<td data-row="1" data-date="2018-03-30"></td>
<td data-row="1" data-date="2018-03-31"></td>
<td data-row="1" data-date="2018-04-01"></td>
<td data-row="1" data-date="2018-04-02"></td>
<td data-row="1" data-date="2018-04-03"></td>
<td data-row="1" data-date="2018-04-04"></td>
<td data-row="1" data-date="2018-04-05"></td>
<td data-row="1" data-date="2018-04-06"></td>
<td data-row="1" data-date="2018-04-07"></td>
<td data-row="1" data-date="2018-04-08"></td>
<td data-row="1" data-date="2018-04-09"></td>
<td data-row="1" data-date="2018-04-10"></td>
<td data-row="1" data-date="2018-04-11"></td>
<td data-row="1" data-date="2018-04-12"></td>
<td data-row="1" data-date="2018-04-13"></td>
<td data-row="1" data-date="2018-04-14"></td>
<td data-row="1" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="2" data-date="2018-03-31"></td>
<td data-row="2" data-date="2018-04-01"></td>
<td data-row="2" data-date="2018-04-02"></td>
<td data-row="2" data-date="2018-04-03"></td>
<td data-row="2" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="2" data-date="2018-04-06"></td>
<td data-row="2" data-date="2018-04-07"></td>
<td data-row="2" data-date="2018-04-08"></td>
<td data-row="2" data-date="2018-04-09"></td>
<td data-row="2" data-date="2018-04-10"></td>
<td data-row="2" data-date="2018-04-11"></td>
<td data-row="2" data-date="2018-04-12"></td>
<td data-row="2" data-date="2018-04-13"></td>
<td data-row="2" data-date="2018-04-14"></td>
<td data-row="2" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-03" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-03</th>
<td data-row="3" data-date="2018-03-30"></td>
<td data-row="3" data-date="2018-03-31"></td>
<td data-row="3" data-date="2018-04-01"></td>
<td data-row="3" data-date="2018-04-02"></td>
<td data-row="3" data-date="2018-04-03"></td>
<td data-row="3" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="3" data-date="2018-04-06"></td>
<td data-row="3" data-date="2018-04-07"></td>
<td data-row="3" data-date="2018-04-08"></td>
<td data-row="3" data-date="2018-04-09"></td>
<td data-row="3" data-date="2018-04-10"></td>
<td data-row="3" data-date="2018-04-11"></td>
<td data-row="3" data-date="2018-04-12"></td>
<td data-row="3" data-date="2018-04-13"></td>
<td data-row="3" data-date="2018-04-14"></td>
<td data-row="3" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-01" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-01</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="4" data-date="2018-03-31"></td>
<td data-row="4" data-date="2018-04-01"></td>
<td data-row="4" data-date="2018-04-02"></td>
<td data-row="4" data-date="2018-04-03"></td>
<td data-row="4" data-date="2018-04-04"></td>
<td data-row="4" data-date="2018-04-05"></td>
<td data-row="4" data-date="2018-04-06"></td>
<td data-row="4" data-date="2018-04-07"></td>
<td data-row="4" data-date="2018-04-08"></td>
<td data-row="4" data-date="2018-04-09"></td>
<td data-row="4" data-date="2018-04-10"></td>
<td data-row="4" data-date="2018-04-11"></td>
<td data-row="4" data-date="2018-04-12"></td>
<td data-row="4" data-date="2018-04-13"></td>
<td data-row="4" data-date="2018-04-14"></td>
<td data-row="4" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-04" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-04</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="5" data-date="2018-03-31"></td>
<td data-row="5" data-date="2018-04-01"></td>
<td data-row="5" data-date="2018-04-02"></td>
<td data-row="5" data-date="2018-04-03"></td>
<td data-row="5" data-date="2018-04-04"></td>
<td data-row="5" data-date="2018-04-05"></td>
<td data-row="5" data-date="2018-04-06"></td>
<td data-row="5" data-date="2018-04-07"></td>
<td data-row="5" data-date="2018-04-08"></td>
<td data-row="5" data-date="2018-04-09"></td>
<td data-row="5" data-date="2018-04-10"></td>
<td data-row="5" data-date="2018-04-11"></td>
<td data-row="5" data-date="2018-04-12"></td>
<td data-row="5" data-date="2018-04-13"></td>
<td data-row="5" data-date="2018-04-14"></td>
<td data-row="5" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="6" data-date="2018-03-30"></td>
<td data-row="6" data-date="2018-03-31"></td>
<td data-row="6" data-date="2018-04-01"></td>
<td data-row="6" data-date="2018-04-02"></td>
<td data-row="6" data-date="2018-04-03"></td>
<td data-row="6" data-date="2018-04-04"></td>
<td data-row="6" data-date="2018-04-05"></td>
<td data-row="6" data-date="2018-04-06"></td>
<td data-row="6" data-date="2018-04-07"></td>
<td data-row="6" data-date="2018-04-08"></td>
<td data-row="6" data-date="2018-04-09"></td>
<td data-row="6" data-date="2018-04-10"></td>
<td data-row="6" data-date="2018-04-11"></td>
<td data-row="6" data-date="2018-04-12"></td>
<td data-row="6" data-date="2018-04-13"></td>
<td data-row="6" data-date="2018-04-14"></td>
<td data-row="6" data-date="2018-04-15"></td>
</tr>
</tbody>
</table>
</div>
</div>
var tableHeight
是问题所在。您已将其设置为 tbody
中第一个 th
的高度,这正是您预期的功能正在发挥作用的地方,即 Projekt 1。(似乎您错过了更新它,因为您已正式发表评论最重要的是说明相同)。
因此,您的点击次数未被评估为 inRange
。您可以通过更改
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top && y <= offset.Top + tableHeight);`
到
var inRange = (x >= offset.Left && x <= offset.Left + offsetWidth) &&
(y >= offset.Top);
希望这对您有所帮助,您可以从此处根据您的要求调整 tableHeight
。另外,@Keith 的建议很准确。
编辑:
检查此 fiddle。根据上述建议,对左栏中日期的点击被评估为 inRange
。水平滚动似乎也有效(您可以点击 04-04-2018 然后点击 02-04-2018 确认)。
您不需要所有这些 javascript,只需将其缩小为:
https://jsfiddle.net/hgbL1h2y/
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).insertBefore('.main-table').addClass('clone');
});
$(".gantt tbody th, .fixed-side").on("click", function(e) {
var row_num = parseInt( $(this).parent().index() ) + 1;
var getWidth = $('.gantt td').outerWidth();
$('.table-wrap').scrollLeft(0 + (getWidth * row_num));
});
setTimeout(function (){
$('.clone').find('tr td').remove();
}, 500)
也改了一些css:
.clone {
position: absolute;
top: 10px;
left: 10px;
position: fixed;
}
.gantt .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone tbody th{
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
}
并添加了边距:
<table class="main-table table gantt" style="margin-left: -10px;">
jQuery(document).ready(function() {
jQuery(".main-table").clone(true).insertBefore('.main-table').addClass('clone');
});
$(".gantt tbody th, .fixed-side").on("click", function(e) {
var row_num = parseInt( $(this).parent().index() ) + 1;
var getWidth = $('.gantt td').outerWidth();
$('.table-wrap').scrollLeft(0 + (getWidth * row_num));
});
setTimeout(function (){
$('.clone').find('tr td').remove();
}, 500)
.table-scroll {
position: relative;
margin: auto;
overflow: hidden;
}
.table-wrap {
width: 100%;
overflow: auto;
}
.table-scroll table {
width: 100%;
margin: auto;
border-collapse: separate;
border-spacing: 0;
}
.table-scroll th,
.table-scroll td {
padding: 5px 10px;
white-space: nowrap;
vertical-align: top;
}
.clone {
position: absolute;
top: 10px;
left: 10px;
position: fixed;
}
.gantt .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone th,
.clone td {
visibility: hidden
}
.clone td,
.clone th {
border-color: transparent
}
.clone tbody th{
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
}
.clone .fixed-side {
visibility: visible;
background-color: #fff;
font-weight: normal;
border: none;
border-right: 2px solid #f4f4f4;
}
.clone thead,
.clone tfoot {
background: transparent;
}
.gantt-h {
font-weight: normal;
color: #b0b0b0;
border-right: 2px solid #f4f4f4;
}
.last {
border-right: 2px solid #f4f4f4;
}
.gantt td {
border-right: 2px solid #f4f4f4;
}
.today {
background-color: pink;
width: 100px;
cursor: pointer
}
.fixed-side{
cursor:pointer
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css">
<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div id="table-scroll" class="table-scroll">
<div class="table-wrap">
<table class="main-table table gantt" style="margin-left: -10px;">
<thead>
<tr>
<th class="fixed-side" scope="col" class="left-h" style="border-bottom:2px solid #f4f4f4;color:#b0b0b0">Task</th>
<th scope="col" class="gantt-h" style="font-weight:normal;color:#b0b0b0;">30 Mar</th>
<th scope="col" class="gantt-h">31 Mar</th>
<th scope="col" class="gantt-h">01 Apr</th>
<th scope="col" class="gantt-h">02 Apr</th>
<th scope="col" class="gantt-h">03 Apr</th>
<th scope="col" class="gantt-h">04 Apr</th>
<th scope="col" class="gantt-h">05 Apr</th>
<th scope="col" class="gantt-h">06 Apr</th>
<th scope="col" class="gantt-h">07 Apr</th>
<th scope="col" class="gantt-h">08 Apr</th>
<th scope="col" class="gantt-h">09 Apr</th>
<th scope="col" class="gantt-h">10 Apr</th>
<th scope="col" class="gantt-h">11 Apr</th>
<th scope="col" class="gantt-h">12 Apr</th>
<th scope="col" class="gantt-h">13 Apr</th>
<th scope="col" class="gantt-h">14 Apr</th>
<th scope="col" class="gantt-h">15 Apr</th>
</tr>
</thead>
<tbody>
<tr>
<th data-name="Projekt 1" class="fixed-side project"><i class="fa fa-folder-open-o" style="color:#9e9e9e"></i> Projekt 1</th>
<td data-row="1" data-date="2018-03-30"></td>
<td data-row="1" data-date="2018-03-31"></td>
<td data-row="1" data-date="2018-04-01"></td>
<td data-row="1" data-date="2018-04-02"></td>
<td data-row="1" data-date="2018-04-03"></td>
<td data-row="1" data-date="2018-04-04"></td>
<td data-row="1" data-date="2018-04-05"></td>
<td data-row="1" data-date="2018-04-06"></td>
<td data-row="1" data-date="2018-04-07"></td>
<td data-row="1" data-date="2018-04-08"></td>
<td data-row="1" data-date="2018-04-09"></td>
<td data-row="1" data-date="2018-04-10"></td>
<td data-row="1" data-date="2018-04-11"></td>
<td data-row="1" data-date="2018-04-12"></td>
<td data-row="1" data-date="2018-04-13"></td>
<td data-row="1" data-date="2018-04-14"></td>
<td data-row="1" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="2" data-date="2018-03-31"></td>
<td data-row="2" data-date="2018-04-01"></td>
<td data-row="2" data-date="2018-04-02"></td>
<td data-row="2" data-date="2018-04-03"></td>
<td data-row="2" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="2" data-date="2018-04-06"></td>
<td data-row="2" data-date="2018-04-07"></td>
<td data-row="2" data-date="2018-04-08"></td>
<td data-row="2" data-date="2018-04-09"></td>
<td data-row="2" data-date="2018-04-10"></td>
<td data-row="2" data-date="2018-04-11"></td>
<td data-row="2" data-date="2018-04-12"></td>
<td data-row="2" data-date="2018-04-13"></td>
<td data-row="2" data-date="2018-04-14"></td>
<td data-row="2" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-03" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-03</th>
<td data-row="3" data-date="2018-03-30"></td>
<td data-row="3" data-date="2018-03-31"></td>
<td data-row="3" data-date="2018-04-01"></td>
<td data-row="3" data-date="2018-04-02"></td>
<td data-row="3" data-date="2018-04-03"></td>
<td data-row="3" data-date="2018-04-04"></td>
<td data-row="2" data-date="2018-04-05"></td>
<td data-row="3" data-date="2018-04-06"></td>
<td data-row="3" data-date="2018-04-07"></td>
<td data-row="3" data-date="2018-04-08"></td>
<td data-row="3" data-date="2018-04-09"></td>
<td data-row="3" data-date="2018-04-10"></td>
<td data-row="3" data-date="2018-04-11"></td>
<td data-row="3" data-date="2018-04-12"></td>
<td data-row="3" data-date="2018-04-13"></td>
<td data-row="3" data-date="2018-04-14"></td>
<td data-row="3" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-01" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-01</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="4" data-date="2018-03-31"></td>
<td data-row="4" data-date="2018-04-01"></td>
<td data-row="4" data-date="2018-04-02"></td>
<td data-row="4" data-date="2018-04-03"></td>
<td data-row="4" data-date="2018-04-04"></td>
<td data-row="4" data-date="2018-04-05"></td>
<td data-row="4" data-date="2018-04-06"></td>
<td data-row="4" data-date="2018-04-07"></td>
<td data-row="4" data-date="2018-04-08"></td>
<td data-row="4" data-date="2018-04-09"></td>
<td data-row="4" data-date="2018-04-10"></td>
<td data-row="4" data-date="2018-04-11"></td>
<td data-row="4" data-date="2018-04-12"></td>
<td data-row="4" data-date="2018-04-13"></td>
<td data-row="4" data-date="2018-04-14"></td>
<td data-row="4" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-04" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-04</th>
<td data-row="2" data-date="2018-03-30"></td>
<td data-row="5" data-date="2018-03-31"></td>
<td data-row="5" data-date="2018-04-01"></td>
<td data-row="5" data-date="2018-04-02"></td>
<td data-row="5" data-date="2018-04-03"></td>
<td data-row="5" data-date="2018-04-04"></td>
<td data-row="5" data-date="2018-04-05"></td>
<td data-row="5" data-date="2018-04-06"></td>
<td data-row="5" data-date="2018-04-07"></td>
<td data-row="5" data-date="2018-04-08"></td>
<td data-row="5" data-date="2018-04-09"></td>
<td data-row="5" data-date="2018-04-10"></td>
<td data-row="5" data-date="2018-04-11"></td>
<td data-row="5" data-date="2018-04-12"></td>
<td data-row="5" data-date="2018-04-13"></td>
<td data-row="5" data-date="2018-04-14"></td>
<td data-row="5" data-date="2018-04-15"></td>
</tr>
<tr>
<th data-date="2018-04-02" class="fixed-side" style="padding-left:27px"><i class="fa fa-file-o" style="color:#9e9e9e"></i> 2018-04-02</th>
<td data-row="6" data-date="2018-03-30"></td>
<td data-row="6" data-date="2018-03-31"></td>
<td data-row="6" data-date="2018-04-01"></td>
<td data-row="6" data-date="2018-04-02"></td>
<td data-row="6" data-date="2018-04-03"></td>
<td data-row="6" data-date="2018-04-04"></td>
<td data-row="6" data-date="2018-04-05"></td>
<td data-row="6" data-date="2018-04-06"></td>
<td data-row="6" data-date="2018-04-07"></td>
<td data-row="6" data-date="2018-04-08"></td>
<td data-row="6" data-date="2018-04-09"></td>
<td data-row="6" data-date="2018-04-10"></td>
<td data-row="6" data-date="2018-04-11"></td>
<td data-row="6" data-date="2018-04-12"></td>
<td data-row="6" data-date="2018-04-13"></td>
<td data-row="6" data-date="2018-04-14"></td>
<td data-row="6" data-date="2018-04-15"></td>
</tr>
</tbody>
</table>
</div>
</div>