一个简单的响应式导航栏

背景

导航对于一个网站重要性,不言而喻。网站上导航一般都置于网站的顶端,每一个导航项都直接详细的列出来,但如果需要去适配移动端的话这样简单粗暴的方法就不大可行了,因为受移动端屏幕宽度所限,在电脑端完美显示的布局在移动端可能就乱掉了(好吧,这是个人码的第一篇博客,之前也没有过写文章的经验,对于“乱掉了”这样口语化的措辞,我也很无奈啊...),所以我们需要为移动端设计专属的导航栏样式。大多数的设计是用一个汉堡按钮(好像是这么叫的?)来代替原来的导航栏,然后通过点击这个按钮来显示或隐藏之。这篇博客就算作在了解了Bootstrap的实现方法原理之后的笔记。

实现原理

直接上代码吧

  • HTML部分
    <nav>
      <div class="navbar-header">
        <!-- 确保无论是宽屏还是窄屏,navbar-brand都显示 -->
        <a href="##" class="navbar-brand">XX网</a>
       <!-- .navbar-toggle样式用于toggle收缩的内容,即nav-collapse collapse样式所在元素 -->
        <button class="navbar-toggle" type="button">
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
        </button>
      </div>
      <!-- 屏幕宽度小于768px时,div.navbar-responsive-collapse容器里的内容都会隐藏,显示icon-bar图标,当点击icon-bar图标时,再展开。屏幕大于768px时,默认显示。 -->
      <div class="collapse navbar-collapse">
        <ul class="nav navbar-nav">
          <li class="active"><a href="##">网站首页</a></li>
          <li><a href="##">系列教程</a></li>
          <li><a href="##">名师介绍</a></li>
          <li><a href="##">成功案例</a></li>
          <li><a href="##">关于我们</a></li>
          </ul>
      </div>
    </nav>

这部分几乎和Bootstrap对应代码完全一致,导航栏的HTML结构显而易见:

- nav
  - div.navbar-header
    - a.navbar-brand
    - button.navbar-toggle(汉堡按钮)
  - div.navbar-collapse(实际导航栏)
    - ul.nav

当视窗宽度大于768px时,直接显示实际导航栏就好,汉堡按钮不显示;小于768px时,显示汉堡按钮,然后实际导航栏的显示则通过点击汉堡按钮由JS来实现导航栏的隐藏和显示,两种情况下导航栏的布局考验的则是对CSS的运用,整个实现原理就是这样。

说到CSS,感觉用好这个东西来写一个布局清晰样式精美的网页很费力(应该是练的太少了,其实自己到现在写的页面,一只手都能数的过来,所以还是太急躁了吧。。。),倒不是CSS原理不懂,就是写出来的东西真没法看,人说CSS是艺术真不是假的。说这几句废话,其实我只是想拖延下贴惨不忍睹的CSS代码

  • CSS部分
* {
  box-sizing: border-box;
}
body {
  margin: 0;
}
a {
  text-decoration: none;
  color: blue;
}
a:hover {
  text-decoration: underline;
}
ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
  }
nav {
  height: 90px;
  padding: 20px;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  background-color: lightblue;
}
.navbar-header {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}     
.navbar-toggle {
  height: 37px;
  display: none;
  border: none;
  background-color: green;
  border-radius: 2px;
  cursor: pointer;
}
.navbar-toggle span {
  display: block;
  width: 2em;
  margin: 3px 0;
  border-bottom: 2px solid #fff;
}
.navbar-brand {
  display: block;
}
.navbar-nav li {
  display: inline-block;
  padding: .5em;
  background-color: lightgreen;
}

@media(max-width: 768px) {
  nav {
    display: block;
  }
  .navbar-header {
    margin-top: 6.5px;
  }  
  .navbar-toggle {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }
  .collapse {
    display: none;
  } 
  .navbar-collapse {
    position: relative;
    top: 26.5px;
  }
  .navbar-collapse li {
    width: 100%;
    border-bottom: 1px solid #fff;;
    text-align: center;
  }
}

因为前些日子看了CSS3里flex的属性,刚好这里就尽量用flex来写的布局,发现属性是真好用;当然好用并不一定随随便便就能用好,所以为了让导航栏里的内容的位置在两种情况下都相对固定,凑了好几个元素的固定长度值,所以写得烂我心里是有点逼数的。

JS的部分就简单了,三条语句,获取元素A,获取元素B,在A上绑定事件,事件触发时操纵B。所以觉得JS比CSS简单是有理由的吧。

  • JS部分
var toggleBtn = document.querySelector('.navbar-toggle')
var collapsedElm = document.querySelector('.navbar-collapse')
toggleBtn.addEventListener('click', function() {
  collapsedElm.classList.toggle('collapse')

代码贴完了再贴下效果图吧,主要看效果,配色什么的忽视就好了

效果图

  • >786px


    image.png
  • <786px


    image.png

    image.png

好了,都贴完了,就这么点东西么(图里的那么大片空白肯定是故意占地方的)?是的,就这么点……总结下。

总结

打个比方,CSS好比是一个人的外表,JS好比是能力,外表不好看都不会有表现的机会,所以包装是有必要而且关键的,同理CSS也是很重要的,先把CSS学熟练吧,起码达到写出的页面能勾起别人继续看下去的兴趣的程度。

第一篇出来就好办了,第二篇、第三篇……都会源源不断的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,722评论 1 92
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,010评论 4 62
  • 生活中,我们总会碰到各种奇葩的设计。让我们看了分分钟想打人,关键还有些特别搞笑。下面来看看吧 第一,奇葩电梯楼层,...
    置青春家装阅读 258评论 0 0
  • 今日更新的新概念是现状,什么是现状通俗化现在的状态?如果这样解释,他对我们的行动没有任何的处境,可是如果我换另一个...
    忠良162阅读 142评论 0 1
  • 小冷,江边无人 北风代替了行走 春天搁浅在沙滩上 我记得仲夏之夜 人声鼎沸,岸边渔火 垂钓者握一杆期许 三两个时辰...
    章小贡阅读 172评论 0 0