使用bootstrap制作响应式导航栏

所谓响应式导航栏,便是能根据窗体大小适配的导航栏,以前见着觉得很高级,而现在终于有机会自己写一个了,先上几张效果图。
这是正常屏幕:
这里写图片描述
这是手机等小屏幕:
这里写图片描述
点击右边后能够显示出菜单
这里写图片描述

要实现这个效果,首先要先导入bootstrap框架

 <link rel='stylesheet prefetch' href='http://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css'>

还有很重要的一点,一定记得加上下面这句话,否则当屏幕变小时点击那个菜单按钮不会有反应:

<script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script src='http://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js'></script>

接下来,如果要将其制成响应式的,还需要将它的内容放在 .collapse navbar-collapse里面。

接下来放代码了,其中sr-only是给阅读障碍人士使用的,这不是重点。
重要关注三个地方,data-target,navbar-fixed-top,navbar-right。
data-target:表示这里将要填充的内容是从哪来的,可以看见代码中data-target中的id和下面div中的id是一样的。
navbar-fixed-top:表示导航栏会跟着页面滚动,不会在页面往下移后就不见了,相同的还有navbar-fixed-bottom。
navbar-right:这个的作用是将导航栏上的组件定位到最右边,同样的还有navbar-left。而至于截图中为什么那些选项明明离屏幕最右边还有点距离呢,因为在上面套了一层 .container。

HTML:

<link href="https://fonts.googleapis.com/css?family=Abril+Fatface|Comfortaa|Yellowtail" rel="stylesheet">

<nav class="navbar navbar-default navbar-fixed-top" role="navigation">
  <div class="container">
    <div class="navbar-header">
      <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#navbar-menu">
        <span class="sr-only">切换导航</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      <span class="icon-bar"></span>
      </button>
      <a href="#" class="navbar-brand nav-title">YinyouPoet</a>
    </div>
    <div class="collapse navbar-collapse" id="navbar-menu">
      <ul class="nav navbar-nav navbar-right">
        <li class="cative"><a href="#">Home</a></li>
        <li class="cative"><a href="#">About</a></li>
        <li class="cative"><a href="#">Portfolio</a></li>
        <li class="cative"><a href="#">Contact</a></li>
      </ul>
    </div>
  </div>
</nav> 



<script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script src='http://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js'></script>

CSS:

*{
  margin:0;
  padding:0;
}
.nav-title{
   font-family: 'Abril Fatface', cursive; 
}
.navbar-header .nav-title:hover,
.navbar-header .nav-title:focus{
  background:#fff;
  color:#000;
}

.cative{
  font-family:'Comfortaa', cursive;
}
.navbar-collapse .navbar-nav li a:hover,
.navbar-collapse .navbar-nav li a:focus{
  color:#000;
  background:#fff;
}

完整代码链接:https://codepen.io/yinyoupoet/pen/eRPwXP?editors=1100



欢迎大家加入QQ群一起交流讨论, 「吟游」程序人生——YinyouPoet

  • 12
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Bootstrap 5提供了一些CSS类和JavaScript插件,可以轻松地实现响应式布局。下面是一个简单的例子,演示如何使用Bootstrap 5来制作一个响应式布局: 1. 首先,将Bootstrap 5的CSS和JavaScript文件添加到你的HTML文件中。你可以通过以下方式来实现: ``` <!-- CSS --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.0/dist/css/bootstrap.min.css"> <!-- JavaScript --> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.0/dist/js/bootstrap.bundle.min.js"></script> ``` 2. 接下来,创建一个基本的HTML结构,包括一个`<header>`、`<nav>`、`<main>`和`<footer>`元素。你可以使用Bootstrap的容器(Container)和栅格系统(Grid System)来实现响应式布局。例如: ``` <header> <nav class="navbar navbar-expand-lg navbar-dark bg-dark"> <div class="container-fluid"> <a class="navbar-brand" href="#">Logo</a> <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <div class="collapse navbar-collapse" id="navbarNav"> <ul class="navbar-nav"> <li class="nav-item"> <a class="nav-link active" aria-current="page" href="#">Home</a> </li> <li class="nav-item"> <a class="nav-link" href="#">About</a> </li> <li class="nav-item"> <a class="nav-link" href="#">Contact</a> </li> </ul> </div> </div> </nav> </header> <main> <div class="container"> <div class="row"> <div class="col-md-8"> <h1>Welcome to my website!</h1> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce euismod, lacus ut laoreet aliquam, purus nisl fermentum metus, vel maximus est magna in massa. Duis auctor justo id metus congue, a pulvinar ipsum ultricies.</p> </div> <div class="col-md-4"> <h3>Latest News</h3> <ul> <li>Lorem ipsum dolor sit amet</li> <li>Consectetur adipiscing elit</li> <li>Fusce euismod, lacus ut laoreet aliquam</li> <li>Purus nisl fermentum metus</li> </ul> </div> </div> </div> </main> <footer> <div class="container"> <div class="row"> <div class="col-md-6"> <p>© 2021 My Website. All rights reserved.</p> </div> <div class="col-md-6"> <ul> <li><a href="#">Privacy Policy</a></li> <li><a href="#">Terms of Use</a></li> <li><a href="#">Site Map</a></li> </ul> </div> </div> </div> </footer> ``` 在这个例子中,我们使用`<header>`、`<nav>`、`<main>`和`<footer>`元素来创建一个基本的页面布局。在`<nav>`元素中,我们使用Bootstrap导航栏(Navbar)组件来创建一个响应式导航栏。在`<main>`元素中,我们使用Bootstrap的栅格系统来创建一个两列布局,其中左边的列占据了八个网格,右边的列占据了四个网格。在`<footer>`元素中,我们再次使用Bootstrap的栅格系统来创建一个两列布局。 3. 最后,你可以使用Bootstrap的CSS类来进一步定制你的页面,例如更改字体、颜色、大小等。例如,你可以使用以下CSS样式来更改页面的背景颜色: ``` body { background-color: #f8f9fa; } ``` 这就是使用Bootstrap 5制作HTML响应式布局的基本步骤。你可以根据自己的需求使用更多的Bootstrap组件和CSS类来定制你的页面,以实现更好的响应式体验。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值