在使用 jQuery 对网页进行布局和设计时,有时我们需要将一个列表元素(li 标签)居中。下面将介绍如何使用 jQuery 将一个 <ul> 标签下的 <li> 标签居中。
方法一:使用 flex 布局实现居中
Flex 布局是 CSS3 新增的一种布局方式,它可以快速的实现居中。
首先在 CSS 中设置 <ul> 标签的样式:
ul { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }
登录后复制
- display: flex;:将 <ul> 标签设置为 flex 布局。
- flex-wrap: wrap;:当 <li> 标签的数量超过一行时,自动换行。
- justify-content: center;:水平方向居中
- align-items: center;:垂直方向居中
此时,<ul> 下的 <li> 元素会自动居中。
方法二:使用 jQuery 计算偏移量居中
在某些情况下,我们可能无法使用 flex 布局,此时可以使用 jQuery 来计算偏移量从而将 <li> 居中。
首先,需要给 <ul> 和 <li> 标签设置以下 CSS 样式:
ul { position: relative; } li { position: absolute; left: 50%; transform: translateX(-50%); }
登录后复制
- position: relative;:为 <ul> 标签设置 position 属性,为后续设置绝对定位做准备。
- position: absolute;:为 <li> 标签设置 position 属性,使其绝对定位,此时可以根据父元素(<ul>)的坐标进行偏移。
- left: 50%;:使 <li> 元素相对于 <ul> 元素居中。
- transform: translateX(-50%);:由于 left: 50% 让 <li> 元素的左侧与 <ul> 元素的中心对齐,此时使用 transform 属性将 <li> 元素向左偏移 50% 即可完全居中。
现在,使用一段 jQuery 代码计算每个 <li> 标签需要的偏移量:
$(window).on('load resize',function(){ var parentWidth = $('ul').width(); // 父元素宽度 $('li').each(function(){ var childWidth = $(this).outerWidth(); // 子元素宽度 var leftOffset = (parentWidth - childWidth) / 2; // 计算偏移量 $(this).css('left', leftOffset + 'px'); // 设置偏移量 }); });
登录后复制
- $(window).on('load resize',function(){});:监听页面 load 和 resize 事件,这样可以在任何时候动态改变屏幕大小时都能保证 <li> 元素居中。
- var parentWidth = $('ul').width();:取得父元素(<ul>)的宽度。
- var childWidth = $(this).outerWidth();:获取每个 <li> 元素的宽度。
- var leftOffset = (parentWidth - childWidth) / 2;:根据父元素宽度和 <li> 元素宽度计算出需要的偏移量。
- $(this).css('left', leftOffset + 'px');:将计算出来的偏移量应用到每个 <li> 元素的 left 属性中。
结语
以上是两种将 <li> 标签居中的实现方法,其中 flex 布局简单快速,且不需要使用 JavaScript,但兼容性较低。而使用 jQuery 计算偏移量的方法适用范围较广,但需要较多的代码和计算,不过是一种用 jQuery 方式实现居中的优秀范例。
以上就是jquery设置li标签居中的详细内容,更多请关注Work网其它相关文章!