前一篇文章中用div布局了豆瓣东西的页面,如果用html代码表示的话大概是这个样子的

<!DOCTYPE html>
<html>
<head>
</head> <body> <div><!--banner-->
    <div></div><!--banner1-->
    <div></div><!--banner2-->
</div> <div></div><!--ad--> <div><!--hierarchy-->
    <div></div><!--left-->
    <div></div><!--right-->
</div>
<div><!--goods-->
    <div></div>
    <div></div>
    <div></div>
</div> </body>
</html>

把上面那段代码保存为1.html,打开之后发现啥也显示出来。

这是为什么?因为我们指定了div,但却没告诉浏览器这块div大小、颜色等属性,那么怎么实现这些呢?CSS啦。

怎么加入css代码呢?用style元素即可,比如下面这样:

<!DOCTYPE html>
<html>
<head>
</head> <body>
<style> div{ background:red;
} </style> <div><!--banner-->
<div></div><!--banner1-->
<div></div><!--banner2-->
</div> <div></div><!--ad--> <div><!--hierarchy-->
<div></div><!--left-->
<div></div><!--right-->
</div>
<div><!--goods-->
<div></div>
<div></div>
<div></div>
</div> </body>
</html>

用浏览器打开发现还是啥也没有,为什么?因为没有指定div的高度、宽度,你怎么可以给一个没有大小的东西填充颜色呢?好,我们给div元素一个大小。

变成下面这样:

<!DOCTYPE html>
<html>
<head>
</head> <body>
<style> div{ height:200px;
width:100px;
background: red;
} </style> <div><!--banner-->
<div></div><!--banner1-->
<div></div><!--banner2-->
</div> <div></div><!--ad--> <div><!--hierarchy-->
<div></div><!--left-->
<div></div><!--right-->
</div>
<div><!--goods-->
<div></div>
<div></div>
<div></div>
</div> </body>
</html>

用浏览器打开之后发现时一个红色的竖条,为什么呢?因为我们上面通过css对所有的div都设置了背景色是红色,怎么能更个性化一些呢?让某个div是红色,某个div是蓝色?可以的,可以给div起一个名字,然后再css代码中指定对应div的名字,这样就针对性的对某个div设置css属性了,好我们再改一下就变成了下面这样:

<!DOCTYPE html>
<html>
<head>
</head> <body>
<style> #banner{ height:200px;
width:100px;
background: red;
}
#ad{
height: 200px;
width:100px;
background:blue;
}
#hierarchy{
height: 200px;
width:100px;
background: green;
} #goods{
height:200px;
width:100px;
background: yellow;
} </style> <div id="banner"><!--banner-->
<div id="banner1"></div><!--banner1-->
<div id="banner2"></div><!--banner2-->
</div> <div id="ad"></div><!--ad--> <div id="hierarchy"><!--hierarchy-->
<div></div><!--left-->
<div></div><!--right-->
</div>
<div id="goods"><!--goods-->
<div id="goods1"></div>
<div id="goods2"></div>
<div id="goods3"></div>
</div> </body>
</html>

人家豆瓣东西那个banner是布满整个浏览器的,而且你几个div的大小也和豆瓣东西的不一样,再调整一下,怎么看出人家height和width用了几个像素呢?我是截图之后放到PS里面用选区工具框选一下,然后再信息窗口里面看一下这个选区的长width和height,然后再看下图像的分辨率,为了方便,切换成像素/厘米 这样就能算出占用几个像素了,调整一下,最后代码变成了这样:

<!DOCTYPE html>
<html>
<head>
</head> <body>
<style> #banner{ height:90px; background: red;
}
#ad{
height: 99px;
width:924px;
background:blue;
}
#hierarchy{
height: 476px;
width:924px;
background: green;
} #goods{
height:488px;
width:924px;
background: yellow;
} </style> <div id="banner"><!--banner-->
<div id="banner1"></div><!--banner1-->
<div id="banner2"></div><!--banner2-->
</div> <div id="ad"></div><!--ad--> <div id="hierarchy"><!--hierarchy-->
<div></div><!--left-->
<div></div><!--right-->
</div>
<div id="goods"><!--goods-->
<div id="goods1"></div>
<div id="goods2"></div>
<div id="goods3"></div>
</div> </body>
</html>

效果如下:

div的大小布局差不多了,可是豆瓣东西里面的div有几个事居中的,那怎么实现呢?可以用margin来实现,margin它是属于盒模型里面的一个概念,margin是指元素边框到元素外边之间的距离,比如:margin : 10px 0px 15px 5px;

它的意思是元素边框距离元素外边的距离分别是上边是10像素、右边是0像素、下边是15像素、左边是5像素,按照上右下左的顺序来写的,如果遇到margin的简写比如margin:0px auto;  这种虽然有两个值,但是我们可以把它“转化为”四个值,按照上右下左的顺序

第一个是0px 第二个是auto,第三个没有了吗?不,返回去,还是0,第四个是auto,这样,所以最后的结果是margin:0px auto 0px  auto

<!DOCTYPE html>
<html>
<head>
</head> <body>
<style> #banner{ height:90px; background: red;
}
#ad{
height: 99px;
width:924px;
background:blue;
margin: 2px auto 2px auto; }
#hierarchy{
height: 476px;
width:924px;
background: green;
margin: 2px auto 2px auto; } #goods{
height:488px;
width:924px;
background: yellow;
margin: 2px auto 2px auto;
} </style> <div id="banner"><!--banner-->
<div id="banner1"></div><!--banner1-->
<div id="banner2"></div><!--banner2-->
</div> <div id="ad"></div><!--ad--> <div id="hierarchy"><!--hierarchy-->
<div></div><!--left-->
<div></div><!--right-->
</div>
<div id="goods"><!--goods-->
<div id="goods1"></div>
<div id="goods2"></div>
<div id="goods3"></div>
</div> </body>

这样就居中啦。

前端学习笔记2017.6.12 CSS控制DIV的更多相关文章

  1. 前端学习笔记2017.6.12 DIV布局网页

    DIV的功能就是把网页划分成逻辑块的. 看下豆瓣东西页面的布局,我们来分析下. 按照先从上到下的原则,把这个页面分成几个块: 首先是最顶端的这个条,这是一个DIV,我们给它起个名字,叫banner 然 ...

  2. 前端学习笔记2017.6.12 HTML的结构以及xhtml、html、xml的区别

    HTML的结构 一个HTML文档可分为几个部分,如下图所示: DOCTYPE部分.head部分和body部分 DOCTYPE部分,这个很重要,可以理解为不同的DOCTYPE意味着不同的html标准,因 ...

  3. 前端学习笔记2017.6.21-html和浏览器的关系以及开发工具

    html文档是一种文件格式, 浏览器可以识别这种文件格式,并能把html文档里面的内容解析出来. 用更贴近程序员的话说就是:html相当于c语言,浏览器相当于c编译器. 开发工具用sublime te ...

  4. 前端学习笔记2017.6.21-html是个什么东西

    html有两种意思,html语言和html格式 html语言是一种面向人类的计算机语言,这是啥意思?人类用html这种语言描述出一个网页的样子,浏览器解析这个语言并展示出来. html格式是一种文件格 ...

  5. 前端学习笔记2017.6.21-引入JS文件的方法

    通过网络引入JS文件 <script src="https://www.xxx.com/aaa.js"></script> 如果是引入本地JS文件 < ...

  6. 【前端】Web前端学习笔记【1】

    ... [2015.12.02-2016.02.22]期间的学习笔记. 相关博客: Web前端学习笔记[2] 1. JS中的: (1)continue 语句 (带有或不带标签引用)只能用在循环中. ( ...

  7. Web前端学习笔记(001)

    ....编号    ........类别    ............条目  ................明细....................时间 一.Web前端学习笔记         ...

  8. web前端学习笔记

    web前端学习笔记(CSS盒子的定位) 相对定位 使用相对定位的盒子的位置常以标准流的排版方式为基础,然后使盒子相对于它在原本的标准位置偏移指定的距离.相对定位的盒子仍在标准流中,它后面的盒子仍以标准 ...

  9. STM32学习笔记(四)——串口控制LED(中断方式)

    目录: 一.时钟使能,包括GPIO的时钟和串口的时钟使能 二.设置引脚复用映射 三.GPIO的初始化配置,注意要设置为复用模式 四.串口参数初始化配置 五.中断分组和中断优先级配置 六.设置串口中断类 ...

随机推荐

  1. [原创]Java动态填充word文档并上传到服务器

    一. 需求背景 在一些特殊应用场合,客户希望在服务器上生成文档的同时并填充数据,客户端的页面不显示打开文档,但是服务器上生成文档对服务器压力很大,目前服务器上生成文档第一种就是方式是jacob, 但是 ...

  2. 教你们在cmd里运行打开游戏,效率很快的。喜欢吧?

    第一步安装好的游戏 环境变量 变量值:把刚才复制好粘贴在里面,前面不用删除. 喜欢吧?这招非常好用.

  3. Uva1401(字典树)

    1401 - Remember the Word Time limit: 3.000 seconds Neal is very curious about combinatorial problems ...

  4. php是如何工作的

    a:前提条件: apache服务器启动正常工作 b:客户端浏览器在地址栏输入一个程序地栏 按回车发送请求 {请求}http://127.0.0.1/day03/1.php c:apache接收请求,并 ...

  5. git 远程库 创建私钥

    1.创建SSH Key.在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步.如果没有,打开Shell(W ...

  6. checking for event2/thread.h... no libevent_pthreads required, failing

    /********************************************************************************** * checking for e ...

  7. Python学习笔记一(基础信息)

    目录 输入输出 数据类型和变量 整数 浮点数 字符串 布尔值 空值 变量 常量 小结 欢迎关注我的博客我在马路边 说明:此笔记不是从零开始,在学习的过程中感觉需要记录一些比较重要和需要重复浏览的信息, ...

  8. 在Azure上通过Powershell创建多Interface的Cisco CSR路由器

    前面通过Json的Template在Azure上创建了Cisco的CSR路由器.但那个Json的template只支持1块网卡.如果需要多网卡的Cisco CSR路由器,可以改上篇文章中提到的Json ...

  9. uboot指令和环境变量

    一.uboot指令 1.printenv(pri) - 打印环境变量 2.setenv - 设置环境变量,和saveenv 配合使用 3.saveenv - 保存环境变量 4.run - 执行设置好的 ...

  10. struts2获得需要的文件或者访问路径

    在struts2中,上传文件的时候遇到一个很好用但是失效的方法,找到如下替代.并且测试了一下request可以得到的相关路径. 得到request对象: HttpServletRequest requ ...