最近在出差,就我一个在这里。客户要做几个页面,涉及到了页面的布局问题,没办法自己得做了。然后就遇到了一些问题。页面不论怎么都不能按照设想的布局。

以前也没有做过网页布局方面的工作。上网上找类似的例子,看的是一头雾水。最终决定自学CSS。

  在网上下载了一本电子书《CSS权威指南》第三版。用了3个钟头看完了这本书。看的时候专拣不知道的看。譬如CSS选择器(这些了,以前就知道,并且使用jQuery就是用的CSS的选择器)、盒子模型了等,所以这些就不看的。另外在学习时,根据CSS参考手册(下载网址:http://css.doyoe.com/)编写样式,再使用360浏览器(或者firebug)进行调试,很快就能明白其中奥妙。

  这3个钟头中,对CSS有了大致的了解,也明白了CSS布局是怎么回事了。下面我将影响CSS布局的3个重要的属性说说:

  (1)display 。在学习这个属性前,要明白CSS把元素主要分为两大类:块元素、行内元素。

    常用的块元素主要有:<div>、<p>、<ul>、<li>、<h1..7>等。换行显示。

    常用的行内元素有:<span>、<a>等。在同一行显示。

    块级元素和行内元素是可以相互转换的,就是通过display属性完成的。

    display可取的值有:

    displaynone | inline | block | list-item | inline-block | table | inline-table | table-caption | table-cell | table-row | table-row-group | table-column | table-column-group | table-footer-group | table-header-group 等等。

    但最重要的就是前三个。

      · none 表示不显示。

      · inline 表示作为行内元素显示。譬如<div>是个块元素,使用了这个属性值,就将和<span>一样了。

      · block 表示作为块元素显示。譬如<span>是行内元素,使用这个属性值,就和<p>一样了。

  

 (2)float 浮动

    在学习float前,得先明白什么是文档流。浏览器在解析html文档内容(这里不说css和javascript、是说单纯的html文档)时,是一流的方式解析的,反映到浏览器上,就是按照从左到右、从上到下的方式显示的。

    使用float属性后,元素会脱离文档流,按照指定的方式进行浮动。

    脱离文档流后,该元素后面的元素就会前移。占有该元素的位置,如果该与元素前的元素也浮动了,就会继续前移。

    float有left和right两种浮动方式。

   (3)position 定位

    使用position属性后,元素也会脱离文档流,按照指定的方式进行定位。

    position:static | relative | absolute | fixed 默认是static。

    relative是相对于祖先元素中,最近的是用position定位的元素,然后依据相对位置进行定位。

    absolute是相对于祖先元素中,最近的是用position定位的元素,然后依据相对位置进行定位。

    fixed是相对于<body>,我们看到的悬浮,就是使用这个值做出的效果。

理解了这3个属性后,我就写出来了一个5级的菜单,按照我希望的方式显示。然后顺利的完成了客户的几个页面。

CSS:布局的三个关键属性:float、position、display的更多相关文章

  1. CSS布局的三种机制

    浮动元素之间没有缝隙,这和行内块还是不一样的,有点区别的! 2) 浮动元素与兄弟盒子之间的关系 注意:解决浮动的四种办法,后三种都是针对浮动元素的父元素的.

  2. CSS传统布局之display属性+float属性+position属性

    这三个属性是传统网页布局中经常用到的属性. 读这篇文章之前,希望你对css布局模型已经有了一定的了解.因为本文的三个属性是和css三个布局模型紧密联系在一起的.因此,如若你并不了解,我推荐你先看一下c ...

  3. CSS 布局:40个教程、技巧、例子和最佳实践

    前言: 布局是WEB开发一个重要的课题,进入XHTML/CSS后,使用TABLE布局的方式逐渐淡出,CSS布局以众多优点成为主流,本文将介绍40个基于CSS的web布局的资源和教程.文章的出处在htt ...

  4. css 布局方式

    布局方式 1 布局:设置元素在网页中的排列方式及显示效果 2 分类: 1 标准流布局(文档流,普通流,静态流) 是默认的布局方式 特点:将元素按照书写顺序及元素类型,从上至下,从左至右排列 2 浮动布 ...

  5. CSS布局(下)

    1.CSS布局之浮动 1.1.float之图文混排 float的意思就是元素漂浮在上层. 可以直接通过设置float属性实现图文混排,代码如下: <div style="width:2 ...

  6. CSS布局:Float布局过程与老生常谈的三栏布局

    原文见博客主站,欢迎大家去评论. 使用CSS布局网页,那是前端的基本功了,什么两栏布局,三栏布局,那也是前端面试的基本题了.一般来说,可以使用CSSposition属性进行布局,或者使用CSSfloa ...

  7. 转:CSS布局:Float布局过程与老生常谈的三栏布局

    使用CSS布局网页,那是前端的基本功了,什么两栏布局,三栏布局,那也是前端面试的基本题了.一般来说,可以使用CSSposition属性进行布局,或者使用CSSfloat属性布局.前者适合布局首页,因为 ...

  8. CSS布局 ——从display,position, float属性谈起(转)

    CSS布局 ——从display,position, float属性谈起   页面布局,或者是在页面上做些小效果的时候经常会用到 display,position和float 属性,如果对它们不是很了 ...

  9. DIV+CSS布局问题:一个宽度不确定的DIV里面放三个水平对齐的DIV,左右两个DIV宽度固定为150px,中间那个DIV充满剩余的宽度

    一个入门的DIV+CSS布局问题:一个宽度不确定的DIV里面放三个水平对齐的DIV,左右两个DIV宽度固定为150px,中间那个DIV充满剩余的宽度. 说明:代码非真实情况下使用,所以直接简单. 没耐 ...

随机推荐

  1. TCP - 流量控制 and 拥塞控制

      1. 流量控制 - Flow Control 序言:数据的传送与接收过程当中很可能出现收方来不及接收的情况,这时就需要对发方进行控制以免数据丢失.利用滑动窗口机制可以很方便的在TCP连接上实现对发 ...

  2. ScrollView与ListView冲突解决

    正 常来说,在ScrollView添加一个ListView后在真机上只会显示ListView的一行多一点,我也不理解为什么会这样,后来我把 ListView的layout_height改成400dip ...

  3. 【Java每日一题】20161103

    package Nov2016; import java.util.List; public class Ques1103 { public void method01(String[] array) ...

  4. expect笔记

    #!/usr/bin/expect -f set ip [lindex $argv 0]; set password [lindex $argv 1];  set timeout 1 spawn ss ...

  5. MAC使用CocoaPods

    前言,還是那句話,按照濤叔下面畫黃色的步驟順序執行就好了 使用CocoaPods兩種方式:使用之前安裝的插件&命令行. 一.利用插件 1.創建項目后添加CocoaPods 2.在文本框中輸入如 ...

  6. MYSQL 解锁与锁表

    解锁 第一种 show processlist; 找到锁进程,kill id ; 第二种 mysql>UNLOCK TABLES; 锁表 锁定数据表,避免在备份过程中,表被更新 mysql> ...

  7. sql server和mysql中分别实现分页功能

    MySQL 在MySQL中,可以用 Limit 来查询第 m 列到第 n 列的记录, 例如: select * from tablename limit m, n sql="select * ...

  8. 【循序渐进学Python】14.数据库的支持

    纯文本只能够实现一些简单有限的功能.如果想要实现自动序列化,也可以使用 shelve 模块和 pickle 模块来实现.但是,如果想要自动的实现数据并发访问,以及更标准,更通用的数据库(databas ...

  9. CSS3 模块

    CSS3 被划分为模块. 其中最重要的 CSS3 模块包括: 选择器 框模型 背景和边框 文本效果 2D/3D 转换 动画 多列布局 用户界面

  10. 【经验之谈】前端面试知识点总结(HTML相关)——附答案

    目录 一.HTML部分 1.浏览器页面有哪三层构成,分别是什么,作用是什么? 2.HTML5的优点与缺点? 3.Doctype作用? 严格模式与混杂模式如何区分?它们有何意义? 4.HTML5有哪些新 ...