我有一个带有JQuery selectable功能的表。我的表可以选择每个 td ,它们位于同一列中。以下是我的完整HTML
<html>
<head>
<link href="/css/jquery-ui.css" rel="stylesheet" type="text/css">
<link href="/css/schedulerGrid.css" rel="stylesheet" type="text/css">
<script src="/js/jquery-ui.js" type="text/javascript">
<script src="/js/jquery.js" type="text/javascript">
<script src="/js/schedulerGrid.js" type="text/javascript">
</head>
<head>
<body>
<div class="scheduler-area">
<div class="scheduler-container">
<table class="scheduler">
<thead>
<tr>
<th class="header">
<div class="header-name">01</div>
</th>
<th class="header">
<div class="header-name">02</div>
</th>
<th class="header">
<div class="header-name">03</div>
</th>
<th class="header">
<div class="header-name">04</div>
</th>
<th class="header">
<div class="header-name">05</div>
</th>
<th class="header">
<div class="header-name">06</div>
</th>
<th class="header">
<div class="header-name">07</div>
</th>
</tr>
</thead>
<tbody>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
<tr>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
<td class="item"></td>
</tr>
</tbody>
</table>
</div>
</div>
</body>
</html>
JavaScript 可选择
var currentCol;
$(document).ready(function(){
$(".scheduler-container").selectable({
filter: ".item",
start: function(event, ui) {
$(".item").removeClass("ui-selected");
},
stop: function(event, ui) {
//Reset selector.
currentCol = undefined;
},
selecting: function(event, ui) {
if (currentCol === undefined) {
currentCol = $(ui.selecting).index();
}
var nthChild = parseInt(currentCol) + 1;
for (var i = 1; i <= $(".scheduler").children('tbody').children('tr').children('.item').length; i++) {
if (i != nthChild) {
$(".item.ui-selecting:nth-child(" + i + ")").each(function() {
$(this).removeClass("ui-selecting");
});
}
}
;
}
});
});
CSS 是
.scheduler-area {
position: relative;
border: 1px solid #000;
padding-top: 37px;
background: #777777;
overflow: hidden;
background: url();
background: -moz-linear-gradient(top, #777777 0%, #494949 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#777777), color-stop(100%,#494949));
background: -webkit-linear-gradient(top, #777777 0%,#494949 100%);
background: -o-linear-gradient(top, #777777 0%,#494949 100%);
background: -ms-linear-gradient(top, #777777 0%,#494949 100%);
background: linear-gradient(to bottom, #777777 0%,#494949 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#777777', endColorstr='#494949',GradientType=0 );
}
.scheduler-container {
overflow-y: auto;
height: 200px;
}
.scheduler {
border-spacing: 0;
width:100%;
}
.scheduler .item + .item {
border-left:1px solid #777777;
}
.scheduler .item, .header {
border-bottom:1px solid #777777;
background: #F7F7F7;
color: #000;
padding: 25px;
}
.scheduler .header {
height: 0;
line-height: 0;
padding-top: 0;
padding-bottom: 0;
color: transparent;
border: none;
white-space: nowrap;
border-left: 1px solid #777777;
border-bottom: none;
}
.scheduler .header:FIRST-CHILD {
border-left: none;
}
.scheduler .header .header-name{
position: absolute;
background: transparent;
color: #fff;
padding: 8px 25px;
top: 0;
margin-left: -26px;
line-height: normal;
border-left: 1px solid #393C44;
width: 165px;
}
.scheduler .header:first-child .header-name{
border: none;
}
.scheduler .ui-selecting {
background: #97B58F;
}
.scheduler .ui-selected {
background: #4C6840;
color: white;
}
.ui-selectable-helper {
border:1px solid #747474;
}
这是JSFIDDLE Link。 我的问题是我想限制 selectable-helper 的选择范围,但我不知道该怎么做。表的元素可在同一列中选择。因此,选择应绑定在同一列中。我怎样才能用CSS或JavaScript来理解它?
答案 0 :(得分:0)
不确定我的问题是否正确。
你想要达到这样的目标吗?
因此,对于此示例,它允许您仅选择列范围之间定义的列。
var columnsRange =[[0,1],[2,3],[0,3],[0,3],[1,3],[3,3],[1,3]];
var currentCol;
$(".scheduler-container").selectable({
filter: ".item",
start: function(event, ui) {
$(".item").removeClass("ui-selected");
},
stop: function(event, ui) {
//Reset selector.
currentCol = undefined;
},
selecting: function(event, ui) {
if (currentCol === undefined) {
currentCol = $(ui.selecting).index();
}
var nthChild = parseInt(currentCol) + 1; //Add one as nthChild is not zero index
for (var i = 1; i <= $(".scheduler").children('tbody').children('tr').children('.item').length; i++) {
if (i != nthChild) {
$(".item.ui-selecting:nth-child(" + i + ")").each(function() {
$(this).removeClass("ui-selecting");
});
}
};
if (!isInRange($(ui.selecting))) {
$(ui.selecting).removeClass("ui-selecting");
}
}
});
function isInRange(cell){
if (cell.closest('tr').index() >=columnsRange[cell.index()][0] && cell.closest('tr').index() <=columnsRange[cell.index()][1])
{
return true;
}
return false;
}