0

I am creating a room reservation system. So i want to make selectable only those td where unselectable="off". Please help me do this.

This is my html code and here is my script that I am using to select them.

<script>
$(function() {
    $( "table" ).selectable(
    {
        filter: 'tbody td unselectable:off '
    }
    );
});
</script>

But nothing is happening. Please help me out with this problem.

            <tr>
                <td unselectable="on" resource="B" style="width: 79px; border-right: 1px solid #000000;
                    border-left: 1px solid #000000; border-bottom: 1px solid #000000; background-color: #ECE9D8;
                    font-family: Tahoma; font-size: 8pt; color: #000000; cursor: default;">
                    <div unselectable="on" style="margin-left: 4px; height: 19px; line-height: 19px;
                        overflow: hidden;">
                        Room B</div>
                </td>
                <td valign="top" unselectable="on" style="width: 1px; border-bottom: 1px solid black;
                    background-color: #FFF4BC;">
                    <div unselectable="on" style="position: relative; height: 19px; overflow: none;">
                        <div unselectable="on" onclick="javascript:event.cancelBubble=true;alert('2');" style="position: absolute;
                            left: 200px; top: -1px; width: 398px; height: 19px; border: 1px solid #000000;
                            background-color: #FFFFFF; white-space: nowrap; overflow: hidden; font-family: Tahoma;
                            font-size: 11px; cursor: pointer;">
                            <div unselectable="on" style="width: 400px; margin-left: -1px; height: 2px; background-color: Blue;
                                font-size: 1px; position: relative;">
                            </div>
                            <div unselectable="on" style="width: 398px; height: 1px; background-color: #000000;
                                font-size: 1px; position: relative;">
                            </div>
                            <div unselectable="on" style="display: block; padding-left: 1px;">
                                Event 3
                            </div>
                        </div>
                    </div>
                </td>
                <td unselectable="off" onclick="javascript:alert('2012-04-01T00:00:00, B');" onmouseover="this.style.backgroundColor='#FFED95';"
                    onmouseout="this.style.backgroundColor='#FFF4BC';" style="border-bottom: 1px solid #000000;
                    width: 19px; background-color: #FFF4BC; cursor: pointer;">
                    <div unselectable="on" style="display: block; width: 18px; height: 19px; border-right: 1px solid #EAD098;">
                        <!-- -->
                    </div>
                </td>
                <td unselectable="off" onclick="javascript:alert('2012-04-02T00:00:00, B');" onmouseover="this.style.backgroundColor='#FFED95';"
                    onmouseout="this.style.backgroundColor='#FFFFD5';" style="border-bottom-width: 1px;
                    border-bottom-style: solid; border-bottom-color: rgb(0, 0, 0); width: 20px; cursor: pointer;
                    background-color: rgb(255, 255, 213);">
                    <div unselectable="on" style="display: block; width: 19px; height: 19px; border-right: 1px solid #EAD098;">
                        <!-- -->
                    </div>
                </td>
                <td unselectable="off" onclick="javascript:alert('2012-04-03T00:00:00, B');" onmouseover="this.style.backgroundColor='#FFED95';"
                    onmouseout="this.style.backgroundColor='#FFFFD5';" style="border-bottom: 1px solid #000000;
                    width: 20px; background-color: #FFFFD5; cursor: pointer;">
                    <div unselectable="on" style="display: block; width: 19px; height: 19px; border-right: 1px solid #EAD098;">
                        <!-- -->
                    </div>
                </td>

'

4

1 回答 1

1

看起来您刚刚弄错了过滤器的语法。您需要使用“属性等于”选择器

$( "table" ).selectable({
    filter: 'tbody td[unselectable="off"]'
});

目前,您正在寻找任何类型的元素,unselectable它是元素的后代td,并使用名为 的伪选择器:off,这两者都不存在。

于 2012-04-18T10:33:17.520 回答