CSS导航条如何添加汉堡条

html-css019

CSS导航条如何添加汉堡条,第1张

一、 head里添加meta移动端的样式

<meta name="viewport" content="width=device-width, initial-scale=1.0"/>

<div class="nav">

<!--汉堡logo menu--> <label for="toggle">☰</label>

<input type="checkbox" id="toggle">

<div class="menu">

<a href="#">Business</a>

<a href="#">Service</a>

<a href="#">Learn more</a>

<a href="#"><span>Free Trial</span></a>

</div></div>

这个汉堡包menu菜单样子其实有代码实现的 "☰" 而且是作为字体显示的,可以直接用font-size直接调整大小

二、css样式 -通用

body{

width: 100%

height: 100%

margin:0 //浏览器默认的body的margin是8px由浏览器的user-agent-stylesheet提供的。所以我们直接覆盖默认就可以了,

}

html{

font-family:'helvetica neue',sans-serif //可以写很多种字体样式,意思是浏览器自己一个个识别,前一个没有就看后一个,一直往后找,直到找到可以用的

}.nav{

float: right

text-align: right

height: 70px

line-height: 70px

border-bottom: 1px solid #eaeaea

}

label{

display: none

}

#toggle{

display:none

}

.menu a{

margin: 0 10px

text-decoration: none

color: gray

}

.menu{

margin: 0 30px 0 0

}

.menu a span{

color:#54d17a

}

//添加@media样式:

@media only screen and (max-width: 500px) {

label{

display: block

cursor: pointer

width: 26px

float: right

}

.menu{

width: 100%

display: none

text-align: center

}

.menu a{

display: block

clear:right

}

#toggle:checked + .menu{ //这是个技术点

transition:all 0.4s ease-in

display: block

}

}

label用for绑定的input,自带了点击事件,点击了label的哪个汉堡logo,input就checked,这样就利用纯CSS实现了点击按钮下拉菜单出现的功能

汉堡按钮就是几个css动画,加上javascript的onclick事件的绑定,很简单的。我给你写了一个,你看看效果吧。这个用了css的媒体查询功能,电脑上看得时候要把浏览器窗口缩小才看得到效果。

文件:index.html

<!DOCTYPE html>

<html>

<head>

<title></title>

<meta name="keywords" content="" />

<meta name="description" content="" />

<link rel="stylesheet" type="text/css" href="css/mp.css" charset="utf-8">

<meta http-equiv="Content-Type" content="text/htmlcharset=gb2312" />

<meta name="viewport" content="width=10,initial-scale=1,user-scalable=no">

<meta name="applicable-device" content="pc,mobile" />

</head>

<body>

<div id="hb" onclick="hb()">

<div id="hb1"></div>

<div id="hb2"></div>

<div id="hb3"></div>

</div>

<ul id="ul1">

<li><a href="index.html">首页</a></li>

<li><a href="lmone/lmone.html">$lanmu1$</a></li>

<li><a href="lmtwo/lmtwo.html">$lanmu2$</a></li>

<li><a href="lmthree/lmthree.html">$lanmu3$</a></li>

<li><a href="lmfour/lmfour.html">$lanmu4$</a></li>

<li><a href="lmfive/lmfive.html">$lanmu5$</a></li>

</ul>

<script type="text/javascript" src="js/hb.js"></script>

</body>

</html>

文件:mp.css

/*手机*/

@media screen and (max-width:700px){

*{

margin:0

padding:0

}

html,body{

overflow:hidden

overflow-y:auto

}

a{

text-decoration:none

color:gray

}

body{

background:rgb(233,234,237)

}

/*汉堡按钮*/

#hb{

float:left

width:20%

height:60px

background:rgb(28,35,39)

overflow:hidden

}

#hb1,#hb2,#hb3{

position:relative

clear:both

width:100%

height:9px

background:gray

}

#hb1{

top:8%

}

#hb2{

top:25%

}

#hb3{

top:43%

}

@keyframes hb1

{

from {

transform:rotate(0deg)

top:8%

}

to {

transform:rotate(45deg)

top:40%

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

transform:rotate(0deg)

top:8%

}

to {

transform:rotate(45deg)

top:40%

}

}

@keyframes hb11

{

from {

transform:rotate(45deg)

top:40%

}

to {

transform:rotate(0deg)

top:8%

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

transform:rotate(45deg)

top:40%

}

to {

transform:rotate(0deg)

top:8%

}

}

@keyframes hb2

{

from {

transform:rotate(0deg)

}

to {

transform:rotate(-45deg)

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

transform:rotate(0deg)

}

to {

transform:rotate(-45deg)

}

}

@keyframes hb22

{

from {

transform:rotate(-45deg)

}

to {

transform:rotate(0deg)

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

transform:rotate(-45deg)

}

to {

transform:rotate(0deg)

}

}

#ul1{

float:left

width:95%

height:15em

background:rgb(28,35,39)

margin-top:1%

padding-left:5%

display:none

}

@keyframes ul1

{

from {

height:0

}

to {

height:15em

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

height:0

}

to {

height:15em

}

}

@keyframes ul11

{

from {

height:15em

}

to {

height:0

}

}

@-webkit-keyframes myfirst /* Safari and Chrome */

{

from {

height:15em

}

to {

height:0

}

}

#ul1 li{

display:inline

float:left

width:95%

margin-top:15px

color:white

}

#ul1 li:hover{

background:gray

}

#ul1 li a{

color:white

}

}

文件:hb.js

hb1=document.getElementById("hb1")

hb2=document.getElementById("hb2")

hb3=document.getElementById("hb3")

ul1=document.getElementById("ul1")

var js=0

function hb(){

if(js%2==0){

ul1.style.display="block"

ul1.style.animation="ul1 0.6s"

hb3.style.display="none"

hb1.style.animation="hb1 0.6s"

hb1.style.transform="rotate(45deg)"

setTimeout("hb1.style.top='40%'","600")

hb2.style.animation="hb2 0.6s"

hb2.style.transform="rotate(-45deg)"

}

if(js%2==1){

ul1.style.animation="ul11 0.6s"

setTimeout("ul1.style.display='none'","600")

setTimeout("hb3.style.display='block'","500")

hb1.style.animation="hb11 0.6s"

hb1.style.transform="rotate(0deg)"

setTimeout("hb1.style.top='8%'","600")

hb2.style.animation="hb22 0.6s"

setTimeout("hb2.style.transform='rotate(0deg)'","600")

}

js=js+1

}

效果图片

工具/原料

bootstrap框架必须有, 还有就是基础的搭建模版, 如果不清楚, 请看"系列一"的文章.

方法/步骤

这里bootstrap使用了html5的一个新的标签nav.

<nav>标签定义导航链接的部分.

使用了样式. .navbar样式标识的是一个导航条.

其中.navbar又包含了:.navbar-header, .navbar-toggle, .navbar-brand

下面先给出一个带有链接的, 而且还支持移动端的例子代码.

bootstrap导航条的可选页面, 有两种(可自己写css定义), 第一种默认的.navbar-default, 效果是:白色的背景黑色的字, 第二种是.navbar-inverse, 效果是:黑色的背景加上白色的字. 只需要选中自己想要的效果即可, 这里需要注意的地方有一点. 就是如果想要这两种默认的其他效果, 就需要自己去实现样式, 可以查看css的源代码, 然后去看.navbar-inverse怎么实现, 然后模仿实现即可, 这是一个笨办法, 还有另外一种方式, 就是使用less, 重新写样式, 因为bootstrap可运行的样式, 也是用less构建的, 也有sass版的, 这里只是简单的介绍一下, 定义好的样式, 这些在以后的经验中还会继续提到.

上面定义了一个简单的带有链接的导航条, 然后相信的说明一下, 这个简单的代码.

1.导航条样式的开始. 这里需要注意一点: 为了增强可访问性(和浏览器的兼容性),务必给每个导航条加上 role="navigation" 属性。方便bootstrap中js处理导航条的显示样式.

2.导航条的页头, 也就是显示在最前面的导航条标题. 这个是bootstrap中的一个带有图标的标签, 然后这里也是在移动端, 就是小于768设备显示的效果.

3.这部分是移动端折叠的部分, 也是为了能够更好的展现页面在移动端.

导航条上除了能够加上一些链接之外, 还可以加上一些按钮, 和一些表单, 例如: 搜索框.

举例子: 按钮, 直接写button标签属性即可. 需要注意的是, 一定要在button的样式上加上.navbar-btn 这样你看到的效果才是比较美观的.

不仅还有按钮, 还有一些下拉列表, 这里, 下拉列表, 就是bootstrap中的下拉. 使用一下的代码来展示下拉样式.

在这里, 如果我们想要把其中的按钮, 链接或者文字, 放到右边, 应该怎么做呢? 我们可以使用bootstarp中的.navbar-left 和 .navbar-right 来做到按钮, 下拉菜单等元素的居左和居右. 需要注意的是, 这个样式只能写在ul中. 看实例, 就明白了.