一個簡單的響應式菜單,僅使用@media query實現.css
上圖的做用就是將普通的菜單在縮小瀏覽器屏幕到必定寬度,或者是在移動設備上的顯示效果.如今分步進行實現:html
第一步:先構建一個普通的菜單,具體顯示如圖:html5
結構以下:css3
<nav class="nav"> <ul> <li class="current"><a href="#">Portfolio</a></li> <li><a href="#">Illustration</a></li> <li><a href="#">Web Design</a></li> <li><a href="#">Print Media</a></li> <li><a href="#">Graphic Design</a></li> </ul> </nav>
/* nav */ .nav { position: relative; margin: 20px 0; } .nav ul { margin: 0; padding: 0; } .nav li { margin: 0 5px 10px 0; padding: 0; list-style: none; display: inline-block; } .nav a { padding: 3px 12px; text-decoration: none; color: #999; line-height: 100%; } .nav a:hover { color: #000; } .nav .current a { background: #999; color: #fff; border-radius: 5px; }
第二步:實現響應式.瀏覽器
下面的例子展現了當屏幕爲600px或者小於600px時,菜單就顯示爲第一幅圖中右邊的結果,CSS代碼以下:ide
@media screen and (max-width: 600px) { .nav { position: relative; min-height: 40px; } .nav ul { width: 180px; padding: 5px 0; position: absolute; top: 0; left: 0; border: solid 1px #aaa; background: #fff url(images/icon-menu.png) no-repeat 10px 11px; border-radius: 5px; box-shadow: 0 1px 2px rgba(0,0,0,.3); } .nav li { display: none; /* hide all <li> items */ margin: 0; } .nav .current { display: block; /* show only current <li> item */ } .nav a { display: block; padding: 5px 5px 5px 32px; text-align: left; } .nav .current a { background: none; color: #666; } /* on nav hover */ .nav ul:hover { background-image: none; } .nav ul:hover li { display: block; margin: 0 0 5px; } .nav ul:hover .current { background: url(images/icon-check.png) no-repeat 10px 7px; } /* right nav */ .nav.right ul { left: auto; right: 0; } /* center nav */ .nav.center ul { left: 50%; margin-left: -90px; } }
試着縮小你的瀏覽器到600px或者小於600px,這是你的菜單應用了600px時的樣式.svn
第三步:兼容性佈局
<nav>和media query是HTML5的內容,IE8及如下不支持.須要添加一下JS來兼容.google
<!--[if lt IE 9]>
<script src="http://css3-mediaqueries-js.googlecode.com/files/css3-mediaqueries.js"></script>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
總結:url
這只是個簡單的響應式例子,你能夠根據本身的頁面佈局應用不一樣的media query,來實現頁面的響應式佈局.