大家好,我是小强老师,今天讲解一小点知识哈

对比了才知道什么好

看不出,很漂亮吧!

有木有倾国倾城的美色。

呵呵,好多东西也是这样的,好的东西只有对比了才觉得好。

我们知道我们网页布局 有三模式。   普通流 normal flow (标准流、常规流)    浮动(float)    和  定位 (position)

标准流

标准流实际上就是一个网页内标签元素正常排列的顺序的意思;比如块级元素会独占一行,行内元素会按顺序依次前后排列;按照这种大前提的布局排列之下绝对不会出现列外的情况叫做标准流布局;

这种布局,我们还是比较喜欢的,因为他是默认的布局模式,稳定, 浮动和 定位毕竟是脱标的。会带来很多不方便。

因此,我们有些地方能用 标准流还是 可以避免用 浮动和 定位  ,我们称之为规避脱标

这里举两个简单例子:

1. margin-left:auto;

假如要做下面的例子:

想要蓝色的小方块 到  红色盒子的右侧。  除了浮动和 定位

其实,我们可以用  margin-left:auto 就可以把蓝色小方块移动到右侧。

代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
  .father{width:350px;height:45px; border:1px solid red; margin:100px auto;}
  .son{width:15px;height:15px; background-color:#00F; margin-left:auto; margin-top:15px; margin-right:5px;}

</style>
</head>

<body>
<div class="father">
    <div class="son"></div>
</div>
</body>
</html>

就可以了。  auto  自动的意思, margin-left:auto   左侧外边距自动 充满  这样,把盒子挤到右侧了。

同时大家也明白了,以前我们写 margin: 0 auto;  为什么可以使块级有宽度和盒子居中对齐。   分开看,就是 margin -left:auto;

margin-right:auto ; 当然上下margin 为0;  左侧自动充满, 右侧也自动充满, 盒子 保证左侧有 自动,右侧也有自动,就在中间了。

当然了,这个元素只能是块级元素  并且左侧不能用其他元素了。这是使用的限制。但是如果遇到了这种情况,我们知道有这种写法就好了。

2. vertical-align:middle;

大家看下面的案例怎么做?

注意红色方块, 必须要有大小的,因为以后要填写背景图片的。

因为后面还有文字,再同一行上,你可能想到浮动或者定位。

其实这里我们用 行内块 +  vertical-align:middle 更合适,因为没有脱标,用的标准流。

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>无标题文档</title>
 <style type="text/css">
 *{margin:0;padding:0}
 h2{width:240px;  margin:100px auto; border:1px solid red; font-size:14px; line-height:35px;}
 h2 s{
 display:inline-block;
 width:15px;
 height:15px;
 background-color:#930;
 vertical-align:middle;
 margin:-3px 5px 0;
 }
 </style>
 </head>

 <body>
 <h2><s></s>我的标题</h2>
 </body>
 </html>

行内块 +  vertical-align  可是两个好基友哦,他们一起使用非常的方便。两者同时出现,vertical-align的本质上是个独立的个体,与后面的line水平的元素是不存在直接的关系的。 可以随意的移动这个红色方块上下位置而不会引起 文字的移动。

来看看淘宝的做法吧:

CSS 规避脱标之两种用法的更多相关文章

  1. CSS——规避脱标流和vertical-align

    规避脱标流: 1.尽量使用标准流. 2.标准流解决不了的使用浮动. 3.浮动解决不了的使用定位. 问题解决:嵌套盒子在不使用定位的情况下定位到右上角 <!DOCTYPE html> < ...

  2. CSS.05 -- 规避脱标 定位的盒子居中、CSS标签规范、溢出隐藏、内容移除(网页优化)、CSS精灵图

    规避脱标   定位的盒子居中显示 Margin:0 auto : 只能让标准流的盒子居中对齐 当A是B的父系,B可以使用 margin-left:auto: 来获得相当于定位right:0:的效果 M ...

  3. 李洪强和你一起学习前端之(9)规避脱标,CSS可见性,滑动门案例

    1  复习昨天知识 1.1 浮动  特点: >浮动的元素不占位置(脱标) >可以将行内元素转化为行内块元素 >块级元素在一行上显示 >设置了浮动的元素,影响其后面的元素   作 ...

  4. css划隔横线的两种方法

    css划隔横线的两种方法  方法一:用DIV,代码如下:(推荐此方法)    <div style="width:800px;height:1px;margin:0px auto;pa ...

  5. c++ operator操作符的两种用法:重载和隐式类型转换,string转其他基本数据类型的简洁实现string_cast

    C++中的operator主要有两个作用,一是操作符的重载,一是自定义对象类型的隐式转换.对于操作符的重载,许多人都不陌生,但是估计不少人都不太熟悉operator的第二种用法,即自定义对象类型的隐式 ...

  6. operator 的两种用法

    C++,有时它的确是个耐玩的东东,就比如operator,它有两种用法,一种是operator overloading(操作符重载),一种是operator casting(操作隐式转换).1.操作符 ...

  7. Service的两种用法及其生命周期

    先来一点基础知识: Service 是android的四大组件之一,与Activity同属于一个级别,它是运行在后台进行服务的组件(例如在后台播放的音乐,播放音乐的同时并不影响其他操作).Servic ...

  8. JSP中的include的两种用法

    1.两种用法 <%@ include file=” ”%> <jsp:include page=” ” flush=”true”/> 2.用法区别 (1)执行时间上区别 < ...

  9. 子查询。ANY三种用法。ALL两种用法。HAVING中使用子查询。SELECT中使用子查询。

    子查询存在的意义是解决多表查询带来的性能问题. 子查询返回单行多列: ANY三种用法: ALL两种用法: HAVING中的子查询返回单行单列: SELECT中使用子查询:(了解就好,避免使用这种方法! ...

随机推荐

  1. POJ 1236 Network of Schools(强连通 Tarjan+缩点)

    POJ 1236 Network of Schools(强连通 Tarjan+缩点) ACM 题目地址:POJ 1236 题意:  给定一张有向图,问最少选择几个点能遍历全图,以及最少加入�几条边使得 ...

  2. Linux新手笔记 ibus

    centos 6.4 32  笔记 一.安装gccyum install gcc    ======================================================== ...

  3. js的初始化

    在项目中遇到了类似于这样的js, myinit.js文件: var wyl_01 = { tip : function(msg){ alert('i am a tip,msg:'+msg); }, t ...

  4. YII2 Gridview

    YII2 Gridview 部分使用规则 1.页面显示的时间戳转换 a. [ 'label'=>'创建日期', 'attribute' => 'created_at', 'filter' ...

  5. JS拖动DIV布局

    方法一: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  6. python2.7_1.2_打印设备名和IPv4地址

    代码如下: # -*- coding: utf-8 -*- import socket def print_machine_info(): host_name = socket.gethostname ...

  7. jQuery + svg/vml

    流程设计器jQuery + svg/vml(Demo7 - 设计器与引擎及表单一起应用例子)   去年就完成了流程设计器及流程引擎的开发,本想着把流程设计器好好整理一下,形成一个一步一步的开发案例,结 ...

  8. 转:从pickle看python类成员的动态加载和类的定位

      pickle是Python轻便的对象序列化工具.使用pickle可以方便地把python对象写入文件对象中,或者像soap那样在socket间传送.     按照python的一贯作风,类的成员在 ...

  9. MFC消息顺序

    1.AfxWndProc()      该函数负责接收消息,找到消息所属的CWnd对象,然后调用AfxCallWndProc 2.AfxCallWndProc()  该函数负责保存消息(保存的内容主要 ...

  10. 数据结构大型实验的记录(done)

    用平衡二叉树的知识实现用户登录系统模拟 基本思路: 类:AVLnode (树的节点类) AVLtree (树的基本操作类 包括insert remove search 平衡树的4种旋转) UserIn ...