以 V2EX 为例深入学习前端开发之基础布局篇一[css/div]

2015-01-21 16:16:46 +08:00
 liyer

昨天在另一帖里说打算写一个系列,说简单,真正静下心来确实很难。
前端是个大杂烩,需要掌握的本领很多,一步步来,先从最基本的CSS和div布局开始吧。
如有不对之处,欢迎指正,希望能与大家共同提高。
废话不多说,这就开始吧。

布局分析

上图是v2ex首页截图,我已经用线框进行了标示,每一个不同颜色的框都是一个容器,从最外层开始分别是:头部、主体、底部三大块。所以,在这个首页的HTML页面里,肯定要有这么三个DIV。

本篇先从头部入手,头部的大容器内有分成了左(Logo)、中(搜索框)、右(导航菜单)这三个部分。所以,头部的div容器我们可以先这样写一个大的布局:

<div class="container">
        <div class="site-header-logo">
            Left
        </div>
        <div class="site-header-search">
            Center
        </div>
        <div class="site-header-menu">
            Right
        </div>
    </div>

上面的代码片段就是我们最原始的布局,有了这个之后,头部区域的布局也就基本确定了。

再来分析一下头部的效果图。

通栏背景色块、主体部分固定宽度且居中。在上面的代码片段中,我们只需对.container设置固定宽度和margin:auto; 即可实现居中并固定宽度。但是不要忘记了,顶部还有一个通栏背景色块。如何解决这个问题呢?

解决办法有两个,第一个是对body设置一个背景图,让其处于水平位置平铺。另一种方法就是再定义一个外层容器,宽度为100%,然后对这个容器进行样式控制。本例中采用第二种,所以经过改进后,上面的代码片段就变成如下这样:

<div class="site-header">
        <div class="container">
            <div class="site-header-logo">
                Left
            </div>
            <div class="site-header-search">
                Center
            </div>
            <div class="site-header-menu">
                Right
            </div>
        </div>
    </div>

样式控制

在前面的代码中,一共出现了5个Class Name:site-header container site-header-logo site-header-search site-header-menu

新建一个style.css文档,定义这些class的样式。

.container{
        width:970px;
        height:auto;
        margin:auto;
    }

    /**
     * Site Header
     */
    .site-header{
        width: 100%;
        height: 44px;
        overflow: hidden;
        background-image: url(../img/site-header-bg-repeat.png);
        background-repeat: repeat;
        background: -webkit-linear-gradient(#6ea3d9,#467aae); /* Chrome & Safari: -webkit- */
        background:    -moz-linear-gradient(#6ea3d9,#467aae); /* Firefox: -moz- */
        background:      -o-linear-gradient(#6ea3d9,#467aae); /* Opera: -o- */
        background:     -ms-linear-gradient(#6ea3d9,#467aae); /* IE: -ms- */
        background:         linear-gradient(#6ea3d9,#467aae); /* Default */
        box-shadow: 0 2px 5px 0 rgba(0,0,0,.4);
    }
    .site-header-logo{
        width:150px;
        height:34px;
        float:left;
        padding:5px 0;
    }

    .site-header-search{
        width:260px;
        height:24px;
        float:left;
        padding:10px 0;
        margin-left:20px;
    }

    .site-header-menu{
        float:right;
        height:24px;
        padding:10px 0;
    }

填入内容

容器搞定了,接下来便要开始写里面的内容了。从左边开始,我们知道,那是个Logo,鼠标点击可以回到首页。由此可知,左边这个区域里的内容就是一个带了链接的图片。

<a href="url" title="title"><img src="ImgUrl" alt="ImgDescription"></a>

再到中间区域,这是一个搜索框,再直白一点就是一个type="text"的input,所以这样写就可以了。

<input type="text" placeholder="Search here...">

最右为导航菜单,本质上就是一组链接。拆分一下,首先是“一组”,字面意义告诉我们这是N个条目,然后是“链接”,首先想到了a标签。这样简单分析之后,这部分内容就可以这么写了。

<ul>
        <li><a href="#">Home</a></li>
        <li><a href="#">Log In</a></li>
        <li><a href="#">Create New Account</a></li>
    </ul>

分别置入对应的区块容器,所以头部完整的HTML代码也就出来了。

<div class="site-header">
        <div class="container">
            <div class="site-header-logo">
                <a href="#"><img src="img/logo-header.png"></a>
            </div>
            <div class="site-header-search">
                <input type="text" placeholder="Search here...">
            </div>
            <div class="site-header-menu">
                <ul>
                    <li><a href="#">Home</a></li>
                    <li><a href="#">Log In</a></li>
                    <li><a href="#">Create New Account</a></li>
                </ul>
            </div>
        </div>
    </div>

样式表

.container{
        /**
         * 定义一个共用的容器,宽度为970px
         * 为什么要定义970?因为v2ex是970px
         * 这个container有什么作用?
         * 最直接的作用就是不需要为每个大区块再定义宽度
         * 另一个作用就是为了方便后续的网页自适应开发
         */
        width:970px;
        height:auto;
        margin:auto;/* 这句的作用是使得这个容器居中,即左右边距相等 */
    }

    /**
     * Site Header
     */
    .site-header{
        width: 100%; /* 全屏宽度 */
        height: 44px; /* Why 44px? 因为v2ex是44px */
        overflow: hidden;
        background-image: url(../img/site-header-bg-repeat.png); /* 这句和下句主要针对旧版本浏览器,比如IE8- */
        background-repeat: repeat;
        /*
         * 以下是通过CSS设置background渐变色
         * 为了兼容各版本浏览器,加上各厂商的私有前缀
         * 最新版本的浏览器均支持css3,所以无需这么繁琐
         */
        background: -webkit-linear-gradient(#6ea3d9,#467aae); /* Chrome & Safari: -webkit- */
        background:    -moz-linear-gradient(#6ea3d9,#467aae); /* Firefox: -moz- */
        background:      -o-linear-gradient(#6ea3d9,#467aae); /* Opera: -o- */
        background:     -ms-linear-gradient(#6ea3d9,#467aae); /* IE: -ms- */
        background:         linear-gradient(#6ea3d9,#467aae); /* Default */
        box-shadow: 0 2px 5px 0 rgba(0,0,0,.4); /* box-shadow是css3的新属性,用于设置box的阴影 */
    }
    .site-header-logo{
        width:150px;
        height:34px;
        float:left;
        padding:5px 0;
    }
    .site-header-logo img{
        height:34px;
    }
    .site-header-search{
        width:260px;
        height:24px;
        float:left;
        padding:10px 0;
        margin-left:20px;
    }
    .site-header-search input[type="text"]{
        width:200px;
        height:24px;
        padding:3px 12px 3px 24px;
        border:0;
        border-radius:12px;
        background:#fff url(../img/icon-search.png) 5px center no-repeat;
    }
    .site-header-search input[type="text"]:focus{
        outline:none; /* 去除焦点边框 */
    }
    .site-header-menu{
        float:right;
        height:24px;
        padding:10px 0;
    }
    .site-header-menu ul{
        line-height:24px;
    }
    .site-header-menu ul li{
        float:left;
        margin-left:20px;
    }
    .site-header-menu ul li a{
        color:#fff;
        text-decoration:none;
    }
    .site-header-menu ul li a:hover{
        text-decoration:underline;
    }

一些必须了解的知识

CSS Reset

各厂商都有自带的默认样式,而Reset的作用就是清除这些差异,然后再重新定义。比如padding、margin、border等等。

自闭合标签

HTML5认为自闭合标签无需添加/

样式属性的先后顺序

位置、大小、浮动、边距、排版、外观
非强制要求,按照个人的习惯书写即可。

Class命名

在小型项目中,class命名规范不是很重要,但养成良好的命名习惯是很有用的,尤其是一个多人维护的项目。
我的一些习惯:

class全小写
使用中划线-连接
使用有意义的名称
尽量英文命名,汉语拼音总觉得很别扭
用父级容器的class作为前缀
赶项目的情况下,上面几点都是浮云

代码缩进

使用tab键,而不是直接敲空格

更多代码书写规范请参考

这篇内容非常好,推荐一看。
Code Guide by @AlloyTeam

待续
GitHub

3229 次点击
所在节点    前端开发
20 条回复
zqjilove
2015-01-21 16:54:35 +08:00
略微懂点CSS,貌似没看到清除浮动的样式,左右浮动都存在,顶部不会出问题?还是我孤陋寡闻了。
liyer
2015-01-21 17:35:59 +08:00
@zqjilove overflow:hidden;
zqjilove
2015-01-21 17:45:51 +08:00
@liyer 长见识了。还可以这样。固定高度,配合overflow:hidden;

改天试试
Sivan
2015-01-21 17:53:58 +08:00
overflow:hidden; 是不好的清浮动方式。
andy12530
2015-01-21 18:07:57 +08:00
@Sivan c
lass="clearfix"
基本上每个网站都有这个class,应该写到标准里去。。

哈哈
liyer
2015-01-21 18:10:21 +08:00
@Sivan clear跟overflow各有千秋吧
现在都用:before :after了
learnshare
2015-01-21 18:11:35 +08:00
不要用 reset,用 http://necolas.github.io/normalize.css/

清除浮动常见的方式:

.clearfix:after{
content: "";
clear: both;
}
liyer
2015-01-21 18:37:22 +08:00
@learnshare 感谢指正。
reset看来争议还是比较大啊 哈哈
在github我放的demo里面,综合了Eric Meyer和normalize,这个也是wordpress自带主题里面的一段reset。
我个人认为很适用。
learnshare
2015-01-21 18:54:49 +08:00
@liyer 一刀把默认样式全砍掉的做法虽然很干净,但太暴力,很多浏览器给的默认样式都是有借鉴意义的。
leer561
2015-01-21 18:58:22 +08:00
.site-header{
width: 100%; /* 全屏宽度 */

为什么要这个width: 100%?
div不是块级元素么?也没见绝对定位或者固定定位
kslr
2015-01-21 19:26:07 +08:00
不明白为什么要发在这里
liyer
2015-01-21 19:42:21 +08:00
@leer561
position:fixed; top:0; 设置了顶部固定的情况下,就需要了。
另一种情况,display:table;
所以我基本上都会写width:100%; 特别是自适应的css。
非常感谢你的指正。
liyer
2015-01-21 19:43:33 +08:00
@kslr 因为在另一篇帖子里说过,已经提前被感谢了。
leer561
2015-01-21 19:46:22 +08:00
@liyer 嗯,我也一般是绝对定位或者固定定位才用,所以才觉得有些奇怪
loveuqian
2015-01-21 20:12:13 +08:00
好。。果然写了。。
如果是你图中这种情况,很有可能footer的底部版权不能固定最底
最近也遇到了这个问题,找了一下好像解决的办法都很麻烦
colincat
2015-01-21 20:19:39 +08:00
这个可以顶
lijinma
2015-01-22 10:13:48 +08:00
谢谢楼主,写的很不错
zqjilove
2015-01-26 11:32:47 +08:00
过了几天,再来围观,还是没见到续集!!!

期待楼主继续。
fuwu1245
2015-02-02 17:59:46 +08:00
能说没看到图片么?
fuwu1245
2015-02-02 17:59:56 +08:00
= = 网速慢。。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/164183

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX