当前位置:首页 > 科技  > 软件

聊聊 CSS 实现自适应导航栏

来源: 责编: 时间:2023-10-23 17:05:33 368观看
导读在移动端应用中,经常会碰到这样的导航栏,导航栏左边通常是一个返回按钮,中间是标题,右边是工具栏,如下:图片值得注意的是,右侧的工具栏是不固定的,有可能有多个,也有可能没有,并且中间的标题是整体居中的,如果标题过长,还能出现省

在移动端应用中,经常会碰到这样的导航栏,导航栏左边通常是一个返回按钮,中间是标题,右边是工具栏,如下:rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

值得注意的是,右侧的工具栏是不固定的,有可能有多个,也有可能没有,并且中间的标题是整体居中的,如果标题过长,还能出现省略号,各种适应场景如下:rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

一、两种不完美实现

假设布局是这样的:rUl28资讯网——每日最新资讯28at.com

<appbar>  <tool>    <a class="icon back"></a>  </tool>  <h2 class="title">我是标题</h2>  <tool class="right">    <a class="link">规则</a>  </tool></appbar>

很多同学可能会直接用 flex 布局让标题自动填充剩余空间,然后设置文本居中。rUl28资讯网——每日最新资讯28at.com

appbar{  display: flex}.title{  flex: 1;  text-align: center;}

这种布局在左右功能区宽度差不多的时候还好,看着像居中的,一旦右边的宽度差异很大,就看着不居中了。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

还有一种是绝对定位,可以实现整体居中。rUl28资讯网——每日最新资讯28at.com

.title{  position: absolute;  left: 0;  right: 0;  text-align: center;}

但是,一旦文本过长,就会和左右的功能区发生重叠,如下:rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

那么,有没有办法可以同时满足这两种情况呢?rUl28资讯网——每日最新资讯28at.com

下面介绍两个方法rUl28资讯网——每日最新资讯28at.com

二、flex 布局实现

还是前面的 flex 布局,相信大家都用过flex:1这样的属性,它可以让子元素平均分配剩余空间。rUl28资讯网——每日最新资讯28at.com

.item{  flex: 1}

如果有3个子元素,那么就会平分为3等分。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

如果仅仅设置左右两边的flex:1,中间宽度不设置,那么中间部分的宽度就自适应内容宽度,由于两边宽度相等,「因此中间的文本看着就是整体居中的」。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

当左右空间不足以均分剩余空间时,会自动压缩另一个空间。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

直到中间部分不足以放下文本内容,出现省略号。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

按照这个原理,先将左右两边设置平均分布。rUl28资讯网——每日最新资讯28at.com

tool{  flex:1;}

这样标题就是整体居中的了。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

然后,只需要将右边菜单居右展示就行了,比如用flex中的justify-content。rUl28资讯网——每日最新资讯28at.com

.right{  display: flex;  justify-content: end;}

这样就就可以很轻松的实现文章开头的效果。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

完整代码可以查看:rUl28资讯网——每日最新资讯28at.com

  • CSS Appbar flex (juejin.cn)[1]
  • CSS Appbar flex (codepen.io)[2]

三、grid 布局实现

grid 布局也能和能轻易的实现这种效果,原理也基本一致。rUl28资讯网——每日最新资讯28at.com

和flex中的flex:1比较类似的是,grid中也有一个单位也能做到均等分布的效果,那就是1fr。rUl28资讯网——每日最新资讯28at.com

div{  display: grid;  grid-template-columns: 1fr auto 1fr;}

这样3个子容器,中间是自适应宽度,左右是自动等分的。rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

原理和前面相同,这里就不重复了,关键实现如下:rUl28资讯网——每日最新资讯28at.com

appbar{  display: grid;  grid-template-columns: 1fr auto 1fr;}.right{  justify-content: end;}

这样也能实现我们想要的效果:rUl28资讯网——每日最新资讯28at.com

图片图片rUl28资讯网——每日最新资讯28at.com

完整代码可以查看:rUl28资讯网——每日最新资讯28at.com

  • CSS Appbar grid (juejin.cn)[3]
  • CSS Appbar grid (codepen.io)[4]

四、总结一下

这样一个实用的布局小技巧,你学到了吗?下面总结一下:rUl28资讯网——每日最新资讯28at.com

  1. 移动端导航栏一般都是标题整体居中的,并且右侧的工具栏是不固定的
  2. 传统的标题flex自适应和绝对定位都有一定的局限性
  3. 在剩余空间充足情况下, flex:1可以让左右两边布局尺寸相同,这样中间标题看着就是居中的了
  4. 在剩余空间不足情况下,中间标题空间会撑满剩余空间,超长则出现省略号
  5. grid 和 flex 原理相同,有一个1fr单位也可以做到均等分布的效果

本文链接:http://www.28at.com/showinfo-26-14604-0.html聊聊 CSS 实现自适应导航栏

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python高频面试题——如何在字符串中删除指定字符

下一篇: 面试官:怎么让Spring扫描我们自定义的注解?

标签:
  • 热门焦点
  • 天猫精灵Sound Pro体验:智能音箱没有音质?来听听我的

    这几年除了手机作为智能生活终端最主要的核心之外,第二个可以成为中心点的产品是什么?——是智能音箱。 手机在执行命令的时候有两种操作方式,手和智能语音助手,而智能音箱只
  • 太卷!Redmi MAX 100英寸电视便宜了:12999元买Redmi史上最大屏

    8月5日消息,从小米商城了解到,Redmi MAX 100英寸巨屏电视日前迎来官方优惠,到手价12999元,比发布价便宜了7000元,在大屏电视市场开卷。据了解,Redmi MAX 100
  • 摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 为什么你不应该使用Div作为可点击元素

    按钮是为任何网络应用程序提供交互性的最常见方式。但我们经常倾向于使用其他HTML元素,如 div span 等作为 clickable 元素。但通过这样做,我们错过了许多内置浏览器的功能。
  • 大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 重估百度丨大模型,能撑起百度的“今天”吗?

    自象限原创 作者|程心 罗辑2023年之前,对于自己的&ldquo;今天&rdquo;,百度也很迷茫。&ldquo;新业务到 2022 年底还是 0,希望 2023 年出来一个 1。&rdquo;这是2022年底,李彦宏
  • 华为开发者大会2023日程公开:开设鸿蒙HarmonyOS 4体验区

    IT之家 7 月 31 日消息,华为今日公布了 HDC.Together 开发者大会 2023 的详细日程。整场大会将于 8 月 4 日-6 日之间举行,届时将发布最新一代鸿蒙 H
  • Android 14发布:首批适配机型公布

    5月11日消息,谷歌在今天凌晨举行了I/O大会,本次发布会谷歌带来了自家的AI语言模型PaLM 2、谷歌Pixel Fold折叠屏、谷歌Pixel 7a手机,同时发布了Androi
Top