02-CSS基础练习:JD首页的制作(快捷导航部分)

我们在上一篇文章中制作的网页最顶部的导航,是属于网页导航。

本文中,Banner图上方的导航,叫做快捷导航(shortcut)。

快捷导航的骨架

我们先制作快捷导航的骨架。如下图所示:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图1

上图中,shortcut-nav-menu-allshortcut-nav-menu-one都是属于shortcut-nav-menu部分,只不过,后者是将父亲撑破了。

为了实现上图,对应的html代码如下:

  1. <!--shortcut-nav部分start-->
  2. <div class="shortcut-nav">
  3. <div class="w">
  4. <div class="shortcut-nav-menu">
  5. <div class="shortcut-nav-menu-all">
  6. <a href="#">全部商品分类</a>
  7. </div>
  8. <div class="shortcut-nav-menu-one" style="color: #fff">
  9. 下一段再讲
  10. </div>
  11. </div>
  12. <div class="shortcut-nav-items">
  13. <ul>
  14. <li><a href="#">服装城</a></li>
  15. <li><a href="#">美妆馆</a></li>
  16. <li><a href="#">京东超市</a></li>
  17. <li><a href="#">生鲜</a></li>
  18. <li><a href="#">全球购</a></li>
  19. <li><a href="#">闪购</a></li>
  20. <li><a href="#">团购</a></li>
  21. <li><a href="#">拍卖</a></li>
  22. <li><a href="#">金融</a></li>
  23. </ul>
  24. </div>
  25. <div class="shortcut-nav-img">
  26. <a href="#">
  27. <img src="images/img2.jpg"/>
  28. </a>
  29. </div>
  30. </div>
  31. </div>
  32. <!--shortcut-nav部分end-->

css代码如下:

  1. /*shortcut-nav部分start*/
  2. .shortcut-nav {
  3. height: 44px;
  4. border-bottom: 2px solid #B1191A;
  5. }
  6. .shortcut-nav-menu { /*撑开和撑破是两回事:撑开说明盒子变成那么大,撑破盒子还是那么大,子盒子很大。子盒子shortcut-nav-menu-one把父亲撑破了*/
  7. width: 210px;
  8. height: 44px; /*浮动的盒子相互影响,不过是否在同一个盒子中*/
  9. float: left;
  10. position: relative;
  11. z-index: 1; /*通过z-index属性将层级放到最高*/
  12. }
  13. .shortcut-nav-menu-all a {
  14. display: block;
  15. width: 190px;
  16. height: 44px;
  17. color: white;
  18. padding: 0 10px;
  19. background-color: #B1191A;
  20. font: 400 15px/44px "microsoft yahei";
  21. }
  22. .shortcut-nav-menu-one {
  23. height: 465px;
  24. margin-top: 2px;
  25. background-color: #C81623;
  26. border-left: 1px solid #B1191A;
  27. border-bottom: 1px solid #B1191A;
  28. /*border-left: 1px solid #000;*/
  29. /*border-bottom: 1px solid #000;*/
  30. }
  31. .shortcut-nav-items {
  32. width: 730px;
  33. height: 44px;
  34. float: left;
  35. }
  36. .shortcut-nav-items li {
  37. float: left;
  38. }
  39. .shortcut-nav-items a {
  40. display: inline-block;
  41. height: 44px;
  42. padding: 0 20px;
  43. color: #333;
  44. font: 400 16px/44px "microsoft yahei";
  45. }
  46. .shortcut-nav-items a:hover {
  47. color: #C81623;
  48. }
  49. .shortcut-nav-img {
  50. width: 200px;
  51. height: 44px;
  52. float: right;
  53. margin-top: -10px;
  54. margin-right: 50px;
  55. /*position: relative;*/
  56. /*left: -50px;*/
  57. /*top: -10px;*/
  58. }
  59. /*shortcut-nav部分end*/

具体的商品分类

商品的具体分类即shortcut-nav-menu-one部分,我们来实现这部分的代码。要求实现的效果如下:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图2

我们在上面的代码中已经给shortcut-nav-menu-one设置了一些属性(例如给左边和下边增加一个像素的红色边框),在此基础之上,需要新增的代码如下:

html代码:

  1. <!--具体的商品分类start-->
  2. <div class="shortcut-nav-menu-one" style="color: #fff">
  3. <ul>
  4. <li>
  5. <a href="">家用电器</a>
  6. <i>></i>
  7. </li>
  8. <li>
  9. <a href="">手机</a>
  10. <span></span>
  11. <a href="">数码</a>
  12. <i>></i>
  13. </li>
  14. <li>
  15. <a href="">电脑</a>
  16. <span></span>
  17. <a href="">办公</a>
  18. <i>></i>
  19. </li>
  20. <li>
  21. <a href="">家居</a>
  22. <span></span>
  23. <a href="">家具</a>
  24. <i>></i>
  25. </li>
  26. <li>
  27. <a href="">男装</a>
  28. <span></span>
  29. <a href="">女装</a>
  30. <i>></i>
  31. </li>
  32. <li></li>
  33. <li></li>
  34. <li></li>
  35. <li></li>
  36. <li></li>
  37. </ul>
  38. </div>
  39. <!--具体的商品分类end-->

css部分如下:

  1. /*具体的商品分类start*/
  2. .shortcut-nav-menu-one ul {
  3. font: 400 14px/31px "microsoft yahei"; /*字体属性具有继承性,让儿子 a 具有此继承性*/
  4. }
  5. .shortcut-nav-menu-one li {
  6. padding-left: 10px;
  7. position: relative;
  8. }
  9. .shortcut-nav-menu-one a{
  10. color: #fff;
  11. }
  12. .shortcut-nav-menu-one i {
  13. right: 10px;
  14. position: absolute;
  15. }
  16. .shortcut-nav-menu-one li:hover {
  17. background-color: #fff;
  18. }
  19. .shortcut-nav-menu-one li:hover a,span,i{
  20. color: #C81623;
  21. }
  22. /*具体的商品分类end*/

轮播图slider + 京东快报

接下来,我们要实现下面这个部分:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图3

组成部分包括:左侧的轮播图、右侧的京东快报 & 充话费 & 右下角的小海报。

结构如下:

  1. <!--main部分start-->
  2. <div class="main">
  3. <div class="w">
  4. <div class="main-slider">
  5. </div>
  6. <div class="main-news">
  7. <div class="main-news-top"> <!--京东快报+充话费-->
  8. <div class="main-news-top-faster"> <!--京东快报-->
  9. </div>
  10. <div class="main-news-top-money"> <!--充话费-->
  11. </div>
  12. </div>
  13. <div class="main-news-bottom">
  14. </div>
  15. </div>
  16. </div>
  17. </div>
  18. <!--main部分end-->

我们依次来讲解。

1、轮播图:main-slider

首页的banner图是首页独有的,所以这部分的css代码要写在index.css里,不要写在base.css里。

html代码如下:

  1. <!--main部分start-->
  2. <div class="main">
  3. <div class="w">
  4. <div class="main-slider">
  5. <a href="">
  6. <img src="images/slider.jpg" alt="">
  7. </a>
  8. <ul> <!--指示点-->
  9. <li>1</li>
  10. <li>2</li>
  11. <li>3</li>
  12. <li>4</li>
  13. <li>5</li>
  14. <li>6</li>
  15. </ul>
  16. <a href="javascript:;" class="arrow-left">&lt;</a> <!--左边的箭头-->
  17. <a href="javascript:;" class="arrow-right">&gt;</a> <!--右边的箭头-->
  18. </div>
  19. </div>
  20. </div>
  21. <!--main部分end-->

注意:超链接 a 标签中,href="javascript:;表示点击超链接时,什么都不做。

CSS代码如下:

  1. .main-slider {
  2. float: left;
  3. margin: 12px 0 0 220px;
  4. width: 730px;
  5. height: 454px;
  6. position: relative;
  7. }
  8. .main-slider ul {
  9. position: absolute;
  10. bottom: 10px;
  11. left: 50%;
  12. margin-left: -66px;
  13. }
  14. .main-slider ul li {
  15. float: left;
  16. width: 18px;
  17. height: 18px;
  18. color: #fff;
  19. background-color: #3E3E3E;
  20. border-radius: 50%; /*圆角矩形*/
  21. line-height: 18px;
  22. text-align: center; /*让 li 里面的文本水平方向居中*/
  23. margin: 0 2px;
  24. cursor: pointer; /*鼠标悬停时变成小手*/
  25. }
  26. .main-slider .arrow-left { /* 轮播图左侧的箭头*/
  27. position: absolute;
  28. top: 50%;
  29. margin-top: -31px;
  30. left: 0px;
  31. width: 28px;
  32. height: 62px;
  33. background-color: rgba(0,0,0,0.3);
  34. color: #fff;
  35. font: 400 22px/62px "sumsun";
  36. text-align: center;
  37. border-radius: 10px 0 0 10px;
  38. }
  39. .main-slider .arrow-left:hover {
  40. background-color: rgba(0,0,0,0.7);
  41. }
  42. .main-slider .arrow-right { /*轮播图右侧的箭头*/
  43. position: absolute;
  44. top: 50%;
  45. margin-top: -31px;
  46. right: 0px;
  47. width: 28px;
  48. height: 62px;
  49. background-color: pink;
  50. background-color: rgba(0,0,0,0.3);
  51. color: #fff;
  52. font: 400 22px/62px "sumsun";
  53. text-align: center;
  54. border-radius: 10px 0 0 10px;
  55. }
  56. .main-slider .arrow-right:hover {
  57. background-color: rgba(0,0,0,0.7);
  58. }

代码解释如下;

(1)轮播图,我们采取的方式是:在超链接 a 里面放一个img标签。

(2)指示点:在一个ul中放多个li。然后通过绝对定位的方式,让ul放在轮播图的正中间(水平方向)。最后详细设置每个指示点li的属性(比如,text-align: center属性可以让li里面的文字水平居中)。

(3)左右两边的箭头:鼠标悬停时,颜色不同。我们通过background-color: rgba(0,0,0,0.3)设置背景的透明度。

最终实现的效果如下:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图4

京东快报

html代码如下:

  1. <div class="main-news-top-faster"> <!--京东快报-->
  2. <div class="main-news-top-faster-title">
  3. <h2>京东快报</h2>
  4. <a href="#">更多 ></a>
  5. </div>
  6. <div class="main-news-top-faster-content">
  7. <ul>
  8. <li><span>[特惠]</span>新闻1</li>
  9. <li><span>[公告]</span>新闻2</li>
  10. <li><span>[特惠]</span>新闻3</li>
  11. <li><span>[公告]</span>新闻4</li>
  12. <li><span>[特惠]</span>新闻5</li>
  13. </ul>
  14. </div>
  15. </div>

css代码如下;

  1. .main-news-top-faster {
  2. height: 163px;
  3. border-bottom: 1px dashed #E4E4E4; /*虚线*/
  4. }
  5. .main-news-top-faster-title {
  6. height: 32px;
  7. line-height: 32px;
  8. border-bottom: 1px dotted #E8E8E8; /*点线*/
  9. padding: 0 15px;
  10. }
  11. .main-news-top-faster-title h2{
  12. float: left;
  13. font: 400 16px/32px "microsoft yahei";
  14. }
  15. .main-news-top-faster-title a {
  16. float: right;
  17. }
  18. .main-news-top-faster-content {
  19. padding: 5px 0 0 15px;
  20. }
  21. .main-news-top-faster-content li {
  22. line-height: 24px;
  23. }
  24. .main-news-top-faster-content span {
  25. font-weight: 700;
  26. margin-right: 5px;
  27. color: #666;
  28. }
  29. .main-news-top-money ul {
  30. width: 250px;
  31. }

3、充话费部分:12个单元格(重要)

(1)步骤一:画表格

充话费这部分,我们不用table标签来做,一般table标签一般是用来放文字的。这里因为有图片,所以我们用ul标签来做,在ul里放12个浮动的li。

如果我们直接这样进行设置:

  1. .main-news-top-money ul {
  2. width: 250px;
  3. }
  4. .main-news-top-money li {
  5. width: 62px;
  6. height: 70px;
  7. border: 1px solid #E8E8E8;
  8. float: left;
  9. }

会发现,效果不尽人意:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图5

上图所示,我们发现,红框部分的12个li,并没有按照我们预期的那样进行排列。因为每个li有border。真实的li当中,它们的border是有重叠的。

解决办法:

父亲宽度不够时,为了让盒子浮动不掉下去,可以给子盒子之上父盒子之下再给一个盒子,让它的宽度略大于父亲的宽度即可。

比如这里,本身这个区域整体的宽度是250,我们就设置ul的宽度是260px即可(满足的条件是:li的宽度_4 < ul的宽度 < li的宽度_5)。

ul的宽度设置为260px之后发现,最右边和最下面的部分会多出来:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图6

我们可以给main-news-top-money设置overflow: hidden,将多余的部分切掉(这是没有办法的事情)。

于是乎,充话费这部分的代码如下:

html部分:

  1. <div class="main-news-top-money"> <!--充话费-->
  2. <ul>
  3. <li></li>
  4. <li></li>
  5. <li></li>
  6. <li></li>
  7. <li></li>
  8. <li></li>
  9. <li></li>
  10. <li></li>
  11. <li></li>
  12. <li></li>
  13. <li></li>
  14. <li></li>
  15. </ul>
  16. </div>

css部分:

  1. .main-news-top-money ul {
  2. width: 260px; /*让宽度略大于整体的宽度250px*/
  3. }
  4. .main-news-top-money li {
  5. width: 62px;
  6. height: 70px;
  7. border: 1px solid #E8E8E8;
  8. float: left;
  9. border-top: 0; /* 将每个单元格的上边框去掉,因为跟单元格的下边框重合了。*/
  10. margin-top: -1px; /* 整体向上移动一个单位,因为边框重合了*/
  11. margin-left: -1px ;/* 整体向左移动一个单位,因为边框重合了*/
  12. }

这样的话,表格就画好了:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图7

(2)步骤二:往表格里填充内容

接下来,我们往表格里填充内容。最终,充话费部分的代码如下:

html部分:

  1. <div class="main-news-top-money"> <!--充话费-->
  2. <ul>
  3. <li>
  4. <a href="">
  5. <i></i> <!--单元格里的图片-->
  6. <span>话费</span>
  7. </a>
  8. </li>
  9. <li>
  10. <a href="">
  11. <i class="main-news-top-money-icon2"></i> <!--单元格里的图片-->
  12. <span>机票</span>
  13. </a>
  14. </li>
  15. <li>
  16. <a href="">
  17. <i></i> <!--单元格里的图片-->
  18. <span>话费</span>
  19. </a>
  20. </li>
  21. <li>
  22. <a href="">
  23. <i></i> <!--单元格里的图片-->
  24. <span>话费</span>
  25. </a>
  26. </li>
  27. <li>
  28. <a href="">
  29. <i></i> <!--单元格里的图片-->
  30. <span>话费</span>
  31. </a>
  32. </li>
  33. <li>
  34. <a href="">
  35. <i></i> <!--单元格里的图片-->
  36. <span>话费</span>
  37. </a>
  38. </li>
  39. <li>
  40. <a href="">
  41. <i></i> <!--单元格里的图片-->
  42. <span>话费</span>
  43. </a>
  44. </li>
  45. <li>
  46. <a href="">
  47. <i></i> <!--单元格里的图片-->
  48. <span>话费</span>
  49. </a>
  50. </li>
  51. <li>
  52. <a href="">
  53. <i></i> <!--单元格里的图片-->
  54. <span>话费</span>
  55. </a>
  56. </li>
  57. <li>
  58. <a href="">
  59. <i></i> <!--单元格里的图片-->
  60. <span>话费</span>
  61. </a>
  62. </li>
  63. <li>
  64. <a href="">
  65. <i></i> <!--单元格里的图片-->
  66. <span>话费</span>
  67. </a>
  68. </li>
  69. <li>
  70. <a href="">
  71. <i></i> <!--单元格里的图片-->
  72. <span>话费</span>
  73. </a>
  74. </li>
  75. </ul>
  76. </div>

index.css部分:

  1. /*充话费部分start*/
  2. .main-news-top-money {
  3. overflow: hidden; /*将多余的部分切掉*/
  4. }
  5. .main-news-top-money ul {
  6. width: 260px; /*让宽度略大于整体的宽度250px*/
  7. }
  8. .main-news-top-money li {
  9. width: 62px;
  10. height: 70px;
  11. border: 1px solid #E8E8E8;
  12. float: left;
  13. border-top: 0; /* 将每个单元格的上边框去掉,因为跟单元格的下边框重合了。*/
  14. margin-top: -1px; /* 整体向上移动一个单位,因为边框重合了*/
  15. margin-left: -1px ;/* 整体向左移动一个单位,因为边框重合了*/
  16. }
  17. .main-news-top-money li a {
  18. display: block;
  19. width: 62px;
  20. height: 30px;
  21. padding-top: 40px;
  22. text-align: center;
  23. line-height: 30px;
  24. position: relative;
  25. }
  26. .main-news-top-money li a i {
  27. width: 25px;
  28. height: 25px;
  29. position: absolute;
  30. top: 13px;
  31. left: 18px;
  32. background: url("../images/fly.png") right top;
  33. }
  34. .main-news-top-money .main-news-top-money-icon2 {
  35. background: url("../images/fly.png") right -25px;
  36. }
  37. /*充话费部分end*/

代码解释:

  • 单元格里的文字:我们可以给单元格里的文字设置padding-top,保证文字位于单元格的底部。

  • 单元格里的图片(精灵图)的位置:通过子绝父相的方式(子是图片<i>本身,相是每个单元格里的超链接文字<a>)。通过子绝父相的方式定位之后,发现精灵图都是一样的图标,目前的处理办法是:手动添加不同的class进行修改精灵图,以后等我们学习js了,就不用这么麻烦了。

画出的表格如下:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图8

今日推荐

接下来,我们开始做下面这部分:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图9

上图中的“今日推荐”,标签可以这样布局:ul > li > a > img

为了防止这部分的内容跑到上面去,我们可以给上面的class-main部分清除浮动。

“今日推荐”这部分的代码如下。

html代码如下:

  1. <!--今日推荐start-->
  2. <div class="today">
  3. <div class="w clearfix">
  4. <div class="today-left fl">
  5. <a href=""></a>
  6. </div>
  7. <div class="today-right">
  8. <ul>
  9. <li><a href=""><img src="images/today1.jpg" alt=""></a></li>
  10. <li><a href=""><img src="images/today2.jpg" alt=""></a></li>
  11. <li><a href=""><img src="images/today3.jpg" alt=""></a></li>
  12. <li><a href=""><img src="images/today4.jpg" alt=""></a></li>
  13. </ul>
  14. <a href="javascript:;" class="arrow-left">&lt;</a> <!--左边的箭头-->
  15. <a href="javascript:;" class="arrow-right">&gt;</a> <!--右边的箭头-->
  16. </div>
  17. </div>
  18. </div>
  19. <!--今日推荐end-->

index.css中的代码如下;

  1. /*今日推荐start*/
  2. .today {
  3. padding: 10px 0 20px;
  4. }
  5. .today-left a{
  6. display: block;
  7. width: 210px;
  8. height: 150px;
  9. background: url("../images/today.jpg");
  10. }
  11. .today-right {
  12. float: right;
  13. width: 1000px;
  14. overflow: hidden; /*隐藏掉右侧超出的几个像素*/
  15. position: relative;
  16. }
  17. .today-right ul {
  18. width: 410%; /*这一点很有技巧*/
  19. }
  20. .today-right li{
  21. float: left;
  22. margin-right: 1px;
  23. }
  24. /*今日推荐end*/

banner两侧的广告

要实现的内容是下图中的箭头处:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图10

注意这部分的div的位置,是放在class="shortcut-nav"class="main"之间的。

两侧的广告其实是一个放在 a 标签里的超大背景图,而且这个大图的宽度超过了版心。所以,超链接的宽度给width: 100%更合适。a 的高度设置为图片的高度即可。

代码实现如下:

html:

  1. <!--网页两侧的广告start-->
  2. <div class="banner-ad">
  3. <a href="http://www.baidu.com"></a>
  4. </div>
  5. <!--网页两侧的广告end-->

index.css:

  1. /*banner两侧的广告start*/
  2. .banner-ad {
  3. position: relative;
  4. }
  5. .banner-ad a {
  6. width: 100%;
  7. height: 644px;
  8. background: url("../images/ad.png") no-repeat center top;
  9. position: absolute;
  10. }
  11. /*banner两侧的广告end*/

上方代码中,我们不用给图片的父亲banner-ad设置高度。

超链接a :我们不知道超链接的宽度是多少,所以直接设置为width: 100%。注意它的背景图的摆放位置,center确保了背景图位于水平方向的正中间,top确保了背景图和父亲定边对齐。

注意,上图中,两侧的广告实现之后发现,蓝框部分的两个位置(main-news-top-fastertoday-left)点击时,发现跳转的是两侧广告的链接,因为它们的层级不够高。解决办法:给蓝框这两个部分加一个position: relative属性即可提高层级。

总结

上一篇文章和这一篇文章,加起来,最终实现的效果如下:

02-CSS基础练习:JD首页的制作(快捷导航部分) - 图11

工程文件如下: