【CSS】1860- CSS 实现自适应导航栏
在移动端应用中,经常会碰到这样的导航栏,导航栏左边通常是一个返回按钮,中间是标题,右边是工具栏,如下
![](https://filescdn.proginn.com/fed6fd857758fb0ae8a022b04b08645c/abac7ae49a6acea663b5eb90861b89c4.webp)
值得注意的是,右侧的工具栏是不固定的,有可能有多个,也有可能没有,并且中间的标题是整体居中的,如果标题过长,还能出现省略号,各种适应场景如下
![](https://filescdn.proginn.com/022b33c56f6c0bcfe671446508a2755a/b7a4eed33a61592773806eda3672a148.webp)
这样的自适应标题如何实现呢?一起看看吧
一、两种不完美实现
假设布局是这样的
<appbar>
<tool>
<a class="icon back"></a>
</tool>
<h2 class="title">我是标题</h2>
<tool class="right">
<a class="link">规则</a>
</tool>
</appbar>
很多同学可能会直接用 flex
布局让标题自动填充剩余空间,然后设置文本居中
appbar{
display: flex
}
.title{
flex: 1;
text-align: center;
}
这种布局在左右功能区宽度差不多的时候还好,看着像居中的,一旦右边的宽度差异很大,就看着不居中了
![](https://filescdn.proginn.com/e57bed6a1741e4e6d495a1f1385ece39/2892d404b7819462bd53d2a764b154a9.webp)
还有一种是绝对定位,可以实现整体居中
.title{
position: absolute;
left: 0;
right: 0;
text-align: center;
}
但是,一旦文本过长,就会和左右的功能区发生重叠,如下
![](https://filescdn.proginn.com/f4f576516bba7c7705ab53668a99bc24/18869548f720676126ec09e84c726938.webp)
那么,有没有办法可以同时满足这两种情况呢?
下面介绍两个方法
二、flex 布局实现
还是前面的 flex
布局,相信大家都用过flex:1
这样的属性,它可以让子元素平均分配剩余空间
.item{
flex: 1
}
如果有3个子元素,那么就会平分为3等分
![](https://filescdn.proginn.com/9c6674802db08dec3220892ef309e822/fec8669f9405a5bc82f49b6f330a612e.webp)
如果仅仅设置左右两边的flex:1
,中间宽度不设置,那么中间部分的宽度就自适应内容宽度,由于两边宽度相等,「因此中间的文本看着就是整体居中的」
![](https://filescdn.proginn.com/d08f3bc69f8c79dcfa895ec38a4cb709/8075b2be206914b4c53f135dafcf7b22.webp)
当左右空间不足以均分剩余空间时,会自动压缩另一个空间
![](https://filescdn.proginn.com/e74ba6f8bbaf6256fbb789472f9d9a4e/f7c940254adb98ed2413a4faa7d93f60.webp)
直到中间部分不足以放下文本内容,出现省略号
![](https://filescdn.proginn.com/8151ced301f1fcbbf0378e57b461a6c6/07a69710e04f477d5f42f4325c8e2c13.webp)
按照这个原理,先将左右两边设置平均分布
tool{
flex:1;
}
这样标题就是整体居中的了
![](https://filescdn.proginn.com/1d8a9764f4dcdd90d83cbcc46309818d/6ed9abad68084215dc0a7aea4fc100a1.webp)
然后,只需要将右边菜单居右展示就行了,比如用flex
中的justify-content
.right{
display: flex;
justify-content: end;
}
这样就就可以很轻松的实现文章开头的效果
![](https://filescdn.proginn.com/022b33c56f6c0bcfe671446508a2755a/b7a4eed33a61592773806eda3672a148.webp)
完整代码可以查看:
CSS Appbar flex (juejin.cn)[1]
CSS Appbar flex (codepen.io)[2]
三、grid 布局实现
grid
布局也能和能轻易的实现这种效果,原理也基本一致。
和flex
中的flex:1
比较类似的是,grid
中也有一个单位也能做到均等分布的效果,那就是1fr
div{
display: grid;
grid-template-columns: 1fr auto 1fr;
}
这样3个子容器,中间是自适应宽度,左右是自动等分的
![](https://filescdn.proginn.com/8e0d0489f010f671796512a264062fc7/dc55bc723c32fd691c7a3bcfa422cad6.webp)
原理和前面相同,这里就不重复了,关键实现如下
appbar{
display: grid;
grid-template-columns: 1fr auto 1fr;
}
.right{
justify-content: end;
}
这样也能实现我们想要的效果
![](https://filescdn.proginn.com/befd0c15cc28c7d81f86f60cc7bb60fb/847573f783c949da92fcca8786d1391a.webp)
完整代码可以查看:
CSS Appbar grid (juejin.cn)[3]
CSS Appbar grid (codepen.io)[4]
四、总结一下
这样一个实用的布局小技巧,你学到了吗?下面总结一下
移动端导航栏一般都是标题整体居中的,并且右侧的工具栏是不固定的
传统的标题flex自适应和绝对定位都有一定的局限性
在剩余空间充足情况下, flex:1可以让左右两边布局尺寸相同,这样中间标题看着就是居中的了
在剩余空间不足情况下,中间标题空间会撑满剩余空间,超长则出现省略号
grid 和 flex 原理相同,有一个1fr单位也可以做到均等分布的效果
一般布局都可以通过 CSS 来实现,足够灵活,不到万不得已,都不要考虑 JS。最后,如果觉得还不错,对你有帮助的话,欢迎点赞、在看、转发❤❤❤
[1]CSS Appbar grid (juejin.cn): https://code.juejin.cn/pen/7291692696299634727
[2]CSS Appbar flex (codepen.io): https://codepen.io/xboxyan/pen/poGoPWj
[3]CSS Appbar grid (juejin.cn): https://code.juejin.cn/pen/7291696160866041906
[4]CSS Appbar grid (codepen.io): https://codepen.io/xboxyan/pen/mdvdmBz