8
    <style>
    .ms_menu ul{list-style:none;}
    .ms_menu ul li{float:left; padding:5px; border-right:1px solid #000000;}
    .ms_menu ul li:last-of-type{border-right:none;}
    </style>

示例 html:

    <div class="ms_menu">
     <ul>
       <li>menu1</li>
       <li>menu2</li>
       <li>menu3</li>
       <li>menu4</li>
       <li>menu5</li>
       </ul>
    </div>

我有一个顶部导航菜单,其中包含一个 LI 向左浮动的 UL。

每个 LI 都有一个 CSS 样式 {border-right 1px solid} 作为每个菜单选项之间的分隔符,我使用 CSS 选择器 last-of-type 来删除最后一个 LI 的右边框。

这一切看起来都很棒,直到重新调整浏览器窗口的大小并将一些 LI 下拉到第二行。last-child 样式规则仍按要求适用,但此时我还想在最后一个 LI 中删除右边界,然后再将其折叠到第二行。

在自动换行/换行之前是否有 jQuery 或通用 Javascript 方法来检测一行上的最后一个元素?

4

1 回答 1

7

您可以测量它们offset

$(window).resize(function() {

    var offsets = [],
        $listItems = $('.ms_menu li');

    $listItems.each(function() {
        offsets.push( $(this).offset().top );
    });

    $.each(offsets, function(i, v) {
        $listItems.eq(i).css('border-right-width', v > offsets[index + 1] ? 0 : 1);
    });

}).resize();
于 2011-08-15T15:32:29.923 回答