我希望在按钮点击时使表格左右滚动,同时保持第一列的位置不变。由于我的数据全部在一个表格中,所以无法创建两个表格代替一个。是否有任何方法可以实现这一点?请参见下面的fiddle。
jQuery:
$(document).ready(function() {
$("#right").on("click", function() {
var position = $("table").position();
$("table").animate({
left: position.left - 200
}, 800);
});
});
$("#left").on("click", function() {
var position = $("table").position();
$("table").animate({
left: position.left + 200
}, 800);
});
CSS:
#table-wrapper {
width: 95%;
float: left;
overflow-x: scroll;
background: #ddd;
}
table {
background: #fff;
width: 1200px;
text-align:center;
overflow: hidden;
position:relative;
}
table thead tr th:first-child,
table tbody tr td:first-child {
background: yellow;
top: auto;
left: 0.5;
position: absolute;
width: 6em;
}
HTML:
<button id="left">←</button>
<button id="right">→</button>
<div id="table-wrapper">
<table border="1">
<thead>
<tr>
<th>Heading1</th>
<th>Heading2</th>
<th>Heading3</th>
<th>Heading4</th>
<th>Heading5</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>12</td>
<td>13</td>
<td>14</td>
<td>15</td>
</tr>
<tr>
<td>2</td>
<td>22</td>
<td>23</td>
<td>24</td>
<td>25</td>
</tr>
<tr>
<td>3</td>
<td>32</td>
<td>33</td>
<td>34</td>
<td>35</td>
</tr>
</tbody>
</table>
</div>
这是我的fiddle代码。