带有colspan的html表格单元格周围的奇怪边框?

时间:2017-06-07 18:06:08

标签: javascript jquery html css html-table

我的问题类似于THIS问题,但我无法使用div而不是使用表格的colspans。

这似乎是一个只出现在Chrome中的问题,但我需要找到一种解决方法。

我的用例与下面的用例非常相似。请注意3.3的顶部边框如何跨越两列,这显然不对。在我的用例中,用户可以更改合并的单元格,这样我就无法设置特定单元格的边框。

如何将单元格的边界限制在自己的单元格中,而不是与colspan大于1的公共单元格共享?

HTML

<div style="padding: 10px">
<table>
    <tr>
        <td>1.1</td>
        <td>1.2</td>
        <td>1.3</td>
        <td>1.4</td>
        <td>1.5</td>
    </tr>
    <tr>
        <td>2.1</td>
        <td>2.2</td>
        <td colspan="2">2.3</td>
        <td>2.5</td>
    </tr>
    <tr>
        <td>3.1</td>
        <td>3.2</td>
        <td>3.3</td>
        <td>3.4</td>
        <td>3.5</td>
    </tr>
    <tr>
        <td>4.1</td>
        <td>4.2</td>
        <td>4.3</td>
        <td>4.4</td>
        <td>4.5</td>
    </tr>
    <tr>
        <td>5.1</td>
        <td>5.2</td>
        <td>5.3</td>
        <td>5.4</td>
        <td>5.5</td>
    </tr>
</table>
</div>

CSS

table {
    table-layout: fixed;
    border-spacing: 0;
    border-collapse: collapse;
}

td {
    border: 1px solid lightgrey;
    height: 60px;
    width: 60px;
    text-align: center;
    vertical-align: middle;
}

td.active {
    border: 1px solid blue;
}

td.brdr-b-hide {
    border-bottom: none;
}
td.brdr-r-hide {
    border-right: none;
}

的JavaScript

var fnActivate = function(target) {
    target.addClass('active');

    if(!target.is(':first-child')) {
        target.prev().addClass('brdr-r-hide')
    }

    var tr = target.closest('tr');
    if(!tr.is(':first-child')) {
        var prevTr = tr.prev();
        $('td', prevTr).eq($('td', tr).index(target)).addClass('brdr-b-hide');

    }
};

var fnDeactivate = function(target) {
    target.removeClass('active');

    if(!target.is(':first-child')) {
        target.prev().removeClass('brdr-r-hide')
    }

    var tr = target.closest('tr');
    if(!tr.is(':first-child')) {
        var prevTr = tr.prev();
        $('td', prevTr).eq($('td', tr).index(target)).removeClass('brdr-b-hide');

    }
}

$('table').on('click', 'td', function(e){
        var target = $(e.currentTarget);

        if(e.ctrlKey && target.hasClass('active')){
            fnDeactivate(target);
        } else if(e.ctrlKey) {
            fnActivate(target);
        } else {
            fnDeactivate($('table td.active'));
            fnActivate(target);
        }

    });

代码:Plunkr

2 个答案:

答案 0 :(得分:2)

使用以下方法解决了问题:

{{1}}

代码:Plunkr

前端有点不同,因为每个单元现在都有自己的1px边框,但暂时它是一个很好的解决方法。

答案 1 :(得分:1)

我认为这个用例最适合outline css属性。 请参阅:http://jsfiddle.net/4zxv4o59/

td.active {
    outline: 1px solid blue;
}
  

大纲不占用空间,它们被绘制在内容之上。

来自https://developer.mozilla.org/en/docs/Web/CSS/outline