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 相关文章推荐
javascript写的简单的计算器,内容很多,方法实用,推荐
Dec 29 Javascript
解析javascript 实用函数的使用详解
May 10 Javascript
IE浏览器不支持getElementsByClassName的解决方法
Aug 27 Javascript
javascript实现下班倒计时效果的方法(可桌面通知)
Jul 10 Javascript
JS判断当前页面是否在微信浏览器打开的方法
Dec 08 Javascript
前端学习笔记style,currentStyle,getComputedStyle的用法与区别
May 28 Javascript
Angular ng-repeat指令实例以及扩展部分
Dec 26 Javascript
Angular.JS中select下拉框设置value的方法
Jun 20 Javascript
React Native 图片查看组件的方法
Mar 01 Javascript
layui实现点击按钮给table添加一行
Aug 10 Javascript
vue在手机中通过本机IP地址访问webApp的方法
Aug 15 Javascript
Vue父子组件之间的通信实例详解
Sep 28 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判断类是否存在函数class_exists用法分析
2014/11/14 PHP
php图像处理函数imagecopyresampled用法详解
2016/12/02 PHP
Yii2.0中使用js异步删除示例
2017/03/10 PHP
js实现ASP分页函数 HTML分页函数
2006/09/22 Javascript
js宝典学习笔记(上)
2007/01/10 Javascript
Jquery插件之多图片异步上传
2010/10/20 Javascript
JQuery中关于jquery.js与jquery.min.js的比较探讨
2013/05/15 Javascript
jQuery判断checkbox(复选框)是否被选中以及全选、反选实现代码
2014/02/21 Javascript
jquery中常用的函数和属性详细解析
2014/03/07 Javascript
Javascript中级语法快速入手
2016/07/30 Javascript
原生js实现弹出层登录拖拽功能
2016/12/05 Javascript
使用BootStrap实现表格隔行变色及hover变色并在需要时出现滚动条
2017/01/04 Javascript
用nodejs实现json和jsonp服务的方法
2017/08/25 NodeJs
vue项目中jsonp跨域获取qq音乐首页推荐问题
2018/05/30 Javascript
js实现敏感词过滤算法及实现逻辑
2018/07/24 Javascript
jquery 回调操作实例分析【回调成功与回调失败的情况】
2019/09/27 jQuery
JavaScript中clientWidth,offsetWidth,scrollWidth的区别
2021/01/25 Javascript
[39:21]LGD vs OG 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.24
2019/09/10 DOTA
[03:12]完美世界DOTA2联赛PWL DAY7集锦
2020/11/06 DOTA
Python中使用Tkinter模块创建GUI程序实例
2015/01/14 Python
Python HTMLParser模块解析html获取url实例
2015/04/08 Python
Python实现求两个csv文件交集的方法
2017/09/06 Python
Python数据类型之列表和元组的方法实例详解
2019/07/08 Python
Python中PyQt5/PySide2的按钮控件使用实例
2019/08/17 Python
windows中安装Python3.8.0的实现方法
2019/11/19 Python
Python基于smtplib协议实现发送邮件
2020/06/03 Python
在pycharm创建scrapy项目的实现步骤
2020/12/01 Python
深入浅析HTML5中的article和section的区别
2018/05/15 HTML / CSS
阿根廷旅游网站:almundo阿根廷
2018/02/12 全球购物
香港交友网站:be2香港
2018/07/22 全球购物
2014年秋季开学演讲稿
2014/05/24 职场文书
家长学校培训材料
2014/08/20 职场文书
实习工作表现评语
2014/12/31 职场文书
初中毕业感言300字
2015/07/31 职场文书
拙作再改《我的收音机情缘》
2022/04/05 无线电
MySQL分区以及建索引的方法总结
2022/04/13 MySQL