Bootstrap导航条的使用和理解3


Posted in Javascript onDecember 14, 2016

以下理论内容copy自Bootstrap中文网 (一个不错的bootstrap学习网站)

导航条

默认样式的导航条

导航条是在您的应用或网站中作为导航页头的响应式基础组件。它们在移动设备上可以折叠(并且可开可关),且在视口(viewport)宽度增加时逐渐变为水平展开模式。 

以下代码和注释是我学习过程中的理解

(注意 引入必要的.css 和 .js查看)

<!DOCTYPE html>
<html lang="zh-CN">
 <head>
 <meta charset="utf-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <meta name="viewport" content="width=device-width, initial-scale=1">
 <title>Bootstrap 导航条模板</title>
 <link href="lib/bootstrap/css/bootstrap.css" rel="stylesheet">
 <!--[if lt IE 9]>
 <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
 <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
 <![endif]-->
 </head>
 <body>

 <nav class="navbar navbar-default">
 <!-- <div class="container-fluid"> -->
 <!-- 将 100% 宽度的布局转换为固定宽度的栅格布局。 -->
 <div class="container">

 <!-- 品牌商标 和 获得更好的移动分组显示-->
 <!-- .navbar-header元素里放了一个button按钮和一个a链接
  先说简单的a链接,用于放置网页logo,导航栏上通常都需要
  button按钮 是一个开关,当在移动设备上显示是,导航条一行显示不完,导航具体内容部分变会崩塌原有的显示形式,收集为多行显示,并隐藏,使用button 按钮可控制其(显示/隐藏)
  -->
 <!-- Brand and toggle get grouped for better mobile display -->

<!-- 以下导航头部 -->
 <div class="navbar-header">
  <!-- 当屏幕缩小时 id为bs-example-navbar-collapse-1的元素隐藏,使用下面这个button 调出 #bs-example-navbar-collapse-1元素 -->
  <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
  <!-- <span class="sr-only">Toggle navigation</span> -->

  <!-- 下面三个span 只是用来显示 三条 横线样式,可以清除注释看看 -->
  <!-- <span class="icon-bar"></span>
  <span class="icon-bar"></span>
  <span class="icon-bar"></span> -->
  更多
  </button>

  <!-- 将导航条内放置品牌标志的地方替换为 <img> 元素即可展示自己的品牌图标。由于 .navbar-brand 已经被设置了内补(padding)和高度(height),你需要根据自己的情况添加一些 CSS 代码从而覆盖默认设置。 -->
  <!-- 放置商标的地方 -->
  <a class="navbar-brand" href="#">Brand</a>
  <!-- a链接里当然也可以图片 或 字体图标 -->
 </div>


<!-- 以下为导航具体内容,身体部分 -->

 <!-- 收集导航链接、表单和其他内容 方便移动设备时。收集隐藏 -->
 <!-- Collect the nav links, forms, and other content for toggling -->
 <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
 <!-- 导航条的内容里有五部分 根据需求更改-->
 <!-- 第一部分 -->
  <ul class="nav navbar-nav">
  <li class="active"><a href="#">链接<span class="sr-only">(current)</span></a></li>
  <li><a href="#">链接</a></li>
  <li class="dropdown">
  <!-- 用来控制 下拉列表显示/隐藏 -->
  <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">下拉 <span class="caret"></span></a>
  <ul class="dropdown-menu">
  <li><a href="#">一个行为</a></li>
  <li><a href="#">另一个行为</a></li>
  <li><a href="#">其他的行为</a></li>
  <!-- .divider 分隔器 与上面分隔一条线 -->
  <li role="separator" class="divider"></li>
  <li><a href="#">分隔开的链接</a></li>
  <li role="separator" class="divider"></li>
  <li><a href="#">另一个分隔开的链接</a></li>
  </ul>
  </li>
  </ul>
  
  <!-- 第二部分 一个文本 -->
  <!-- 把文本包裹在 .navbar-text中时,为了有正确的行距和颜色,通常使用 <p> 标签。 -->
  <p class="navbar-text">文本内容</p>

  <!-- 第三部分 是一个表单-->
  <!-- 将表单放置于 .navbar-form 之内可以呈现很好的垂直对齐,并在较窄的视口(viewport)中呈现折叠状态。 使用对齐选项可以规定其在导航条上出现的位置。 -->
  <form class="navbar-form navbar-left" role="search">
  <div class="form-group">
  <input type="text" class="form-control" placeholder="请输入内容">
  </div>
  <button type="submit" class="btn btn-default">提交</button>
  </form>

  <!-- 第四部分是一个独立按钮 -->
  <!-- 对于不包含在 <form> 中的 <button> 元素,加上 .navbar-btn 后,可以让它在导航条里垂直居中。有一些对于为辅助设备提供可识别标签的方法,例如, aria-label、aria-labelledby 或者 title 属性。如果这些方法都没有,屏幕阅读器将使用 placeholder 属性(如果这个属性存在的话),但是请注意,使用 placeholder 代替其他识别标签的方式是不推荐的。 -->
  <button type="button" class="btn btn-default navbar-btn">独立按钮</button>

  <!-- 第五部分 -->
  <!-- 或许你希望在标准的导航组件之外添加标准链接,那么,使用 .navbar-link 类可以让链接有正确的默认颜色和反色设置。 -->
  <p class="navbar-text">正常文本<a href="#" class="navbar-link"> 非导航链接</a></p>
  
  

 </div><!-- /.navbar-collapse -->

 </div><!-- /.container-fluid -->
 </nav>



 <script src="lib/jquery/jquery.js"></script>
 <script src="lib/bootstrap/js/bootstrap.js"></script>
 </body>
</html>

组件排列

通过添加 .navbar-left .navbar-right 工具类让导航链接、表单、按钮或文本对齐。两个类都会通过 CSS 设置特定方向的浮动样式。例如,要对齐导航链接,就要把它们放在个分开的、应用了工具类的 <ul> 标签里。

这些类是 .pull-left 和 .pull-right 的 mixin 版本,但是他们被限定在了媒体查询(media query)中,这样可以更容易的在各种尺寸的屏幕上处理导航条组件。

向右侧对齐多个组件
导航条目前不支持多个 .navbar-right 类。为了让内容之间有合适的空隙,我们为最后一个 .navbar-right 元素使用负边距(margin)。如果有多个元素使用这个类,它们的边距(margin)将不能按照你的预期正常展现。

我们将在 v4 版本中重写这个组件时重新审视这个功能。

 固定在顶部

添加 .navbar-fixed-top 类可以让导航条固定在顶部,还可包含一个 .container 或 .container-fluid 容器,从而让导航条居中,并在两侧添加内补(padding)。

需要为 body 元素设置内补(padding)
这个固定的导航条会遮住页面上的其它内容,除非你给 <body> 元素底部设置了 padding。用你自己的值,或用下面给出的代码都可以。提示:导航条的默认高度是 50px。

body { padding-top: 70px; }

<nav class="navbar navbar-default navbar-fixed-top">
 <div class="container">
 ...
 </div>
 </nav>

 固定在底部

添加 .navbar-fixed-bottom 类可以让导航条固定在底部,并且还可以包含一个 .container 或 .container-fluid 容器,从而让导航条居中,并在两侧添加内补(padding)。

需要为 body 元素设置内补(padding)
这个固定的导航条会遮住页面上的其它内容,除非你给 <body> 元素底部设置了 padding。用你自己的值,或用下面给出的代码都可以。提示:导航条的默认高度是 50px。

body { padding-bottom: 70px; }

<nav class="navbar navbar-default navbar-fixed-bottom">
 <div class="container">
 ...
 </div>
 </nav>

静止在顶部

通过添加 .navbar-static-top 类即可创建一个与页面等宽度的导航条,它会随着页面向下滚动而消失。还可以包含一个 .container 或 .container-fluid 容器,用于将导航条居中对齐并在两侧添加内补(padding)。

通过添加 .navbar-static-top 类即可创建一个与页面等宽度的导航条,它会随着页面向下滚动而消失。还可以包含一个 .container 或 .container-fluid 容器,用于将导航条居中对齐并在两侧添加内补(padding)。to center and pad navbar content.

<nav class="navbar navbar-default navbar-static-top">
 <div class="container">
 ...
 </div>
</nav>

 反色的导航条

通过添加 .navbar-inverse 类可以改变导航条的外观。

<nav class="navbar navbar-inverse">
 ...
</nav>

如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
showModalDialog 和 showModelessDialog
Jan 22 Javascript
JavaScript对象模型-执行模型
Apr 28 Javascript
jquery tab插件制作实现代码
Jun 22 Javascript
jquery获取input的value问题说明
Aug 19 Javascript
自己整理的一个javascript日期处理函数
Oct 16 Javascript
基于jQuery的动态表格插件
Mar 28 Javascript
分享一个用Mootools写的鼠标滑过进度条改变进度值的实现代码
Dec 12 Javascript
js+div实现图片滚动效果代码
Feb 10 Javascript
js中的事件捕捉模型与冒泡模型实例分析
Jan 10 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 Javascript
全屏滚动插件fullPage.js使用实例解析
Oct 21 Javascript
原生JS实现无缝轮播图片
Jun 24 Javascript
jQuery学习笔记之入门
Dec 14 #Javascript
Bootstrap轮播图的使用和理解4
Dec 14 #Javascript
12 款 JS 代码测试必备工具(翻译)
Dec 13 #Javascript
使用BootStrap实现悬浮窗口的效果
Dec 13 #Javascript
关于微信jssdk实现多图片上传的一点心得分享
Dec 13 #Javascript
微信页面倒计时代码(解决safari不兼容date的问题)
Dec 13 #Javascript
JS实现微信弹出搜索框 多条件查询功能
Dec 13 #Javascript
You might like
PHP 自定义错误处理函数trigger_error()
2013/03/26 PHP
ThinkPHP实现递归无级分类――代码少
2015/07/29 PHP
PHP文件与目录操作示例
2016/12/24 PHP
Yii框架分页实现方法详解
2017/05/20 PHP
详解PHP发送邮件知识点
2018/05/06 PHP
Javascript &amp; DHTML 实例编程(教程)DOM基础和基本API
2007/06/02 Javascript
JQuery实现绚丽的横向下拉菜单
2013/12/19 Javascript
jquery实现的仿天猫侧导航tab切换效果
2015/08/24 Javascript
分享jQuery插件的学习笔记
2016/01/14 Javascript
JQuery点击事件回到页面顶部效果的实现代码
2016/05/24 Javascript
jQuery实现的网格线绘制方法
2016/06/20 Javascript
js实现上下左右弹框划出效果
2017/03/08 Javascript
JS实现汉字与Unicode码相互转换的方法详解
2017/04/28 Javascript
jQuery实现简单的手风琴效果
2020/04/17 jQuery
微信小程序删除处理详解
2017/08/16 Javascript
vue自定义指令directive的使用方法
2019/04/07 Javascript
jQuery中DOM常见操作实例小结
2019/08/01 jQuery
vue从零实现一个消息通知组件的方法详解
2020/03/16 Javascript
基于js判断浏览器是否支持webGL
2020/04/18 Javascript
vue移动端弹起蒙层滑动禁止底部滑动操作
2020/07/22 Javascript
[01:31:03]DOTA2完美盛典全回顾 见证十五项大奖花落谁家
2017/11/28 DOTA
在Python的Django框架中更新数据库数据的方法
2015/07/17 Python
python运行时间的几种方法
2016/06/17 Python
python3实现读取chrome浏览器cookie
2016/06/19 Python
python的unittest测试类代码实例
2017/12/07 Python
python实现简易内存监控
2018/06/21 Python
TensorFlow tf.nn.conv2d实现卷积的方式
2020/01/03 Python
python opencv 图像边框(填充)添加及图像混合的实现方法(末尾实现类似幻灯片渐变的效果)
2020/03/09 Python
Python新手学习raise用法
2020/06/03 Python
python脚本定时发送邮件
2020/12/22 Python
城建学院毕业生自荐信
2014/01/31 职场文书
党的群众路线整改落实情况汇报
2014/10/28 职场文书
党员示范岗材料
2014/12/19 职场文书
孟佩杰观后感
2015/06/17 职场文书
立秋之描写立秋的作文(五年级)
2019/08/08 职场文书
python 提取html文本的方法
2021/05/20 Python