CSS 规避脱标之两种用法

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

对比了才知道什么好

看不出,很漂亮吧!

有木有倾国倾城的美色。

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

我们知道我们网页布局 有三模式。   普通流 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 更合适,因为没有脱标,用的标准流。

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

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

来看看淘宝的做法吧:

时间: 2024-10-12 03:28:02

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

网页设计制作CSS实现隔行换色两种方法

网页设计制作CSS实现隔行换色两种方法 2007-12-21 20:59:44  来源:网页教学网 网页设计制作,CSS实现隔行换色两种方法: 第一种方法: 以下为引用的内容:<style type="text/css">UL.myul1 LI{}</style><ul class="myul1"><li id="li1">111</li><li id="li2"

JSP中的include的两种用法

1.两种用法 <@inlcude file ="header.jsp"/> 此时引入的是静态的jsp文件,它将引入的jsp中的源代码原封不动地附加到当前文件中,所以在jsp程序中使用这个指令的时候file里面的值(即要导入的文件)不能带多余的标签或是与当前jsp文件重复的东西.例如里面不要包含<html><body>这样的标签,因为是把源代码原封不动的附加过来,所以会与当前的jsp中的这样的标签重复导致出错. <jsp:include page

Android---24---Spinner的两种用法

Spinner是一个列表选择框,它有两种用法: 一种是使用android:entries属性的,一种是不使用该属性,通过动态的添加Adapter来实现的. 第一种: MainActivity.java: import android.app.Activity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import andr

operator 的两种用法

C++,有时它的确是个耐玩的东东,就比如operator,它有两种用法,一种是operator overloading(操作符重载),一种是operator casting(操作隐式转换). 1.操作符重载C++可以通过operator实现重载操作符,格式如下:类型T operator 操作符 (),比如重载+,比如下面这个例子template<typename T> class A{public:     const T operator+(const T& rhs)     {  

jsp中include的两种用法

JSP中的include的两种用法 1.两种用法 <%@ include file=” ”%> <jsp:include page=” ” flush=”true”/> 2.用法区别 (1)执行时间上区别 <%@ include file=”relativeURI”%>                   是在翻译阶段执行 <jsp:include page=”relativeURI” flush=”true” />  在请求处理阶段执行. (2)引入内容的

css如何实现一个文字两种颜色代码实例

css如何实现一个文字两种颜色代码实例:在实际应用中可能需要设置文本效果比较炫酷.有一种效果就是将一个文字设置为两种颜色,使用普通的方法肯定是无法实现.下面就分享一下实现此功能的代码实例: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/&qu

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

C++中的operator主要有两个作用,一是操作符的重载,一是自定义对象类型的隐式转换.对于操作符的重载,许多人都不陌生,但是估计不少人都不太熟悉operator的第二种用法,即自定义对象类型的隐式转换,我们下面就用以下这个小例子温故一下这两种用法: 1 #include <iostream> 2 #include <sstream> 3 using namespace std; 4 5 class FuncObj 6 { 7 public: 8 FuncObj(int n):

include的两种用法之间的区别

以下是对include 两种用法的区别 主要有两个方面的不同; 一:执行时间上: <%@ include file="relativeURI"%> 是在翻译阶段执行 <jsp:include page="relativeURI" flush="true" /> 在请求处理阶段执行. 二:引入内容的不同: <%@ include file="relativeURI"%> 引入静态文本(html

夺命雷公狗C/C++-----5---include的两种用法

我们的include是有两种用法的,如: 上面这种就是在头文件方式进行引入的,  include  <>  括号的是包含系统文件的.... 还有一种,比如我首先写个头文件先,如下所示: 然后我们在愿文件里面进行引入,如下所示: 这样也是成功的引入了... 总结   include 的区别 #include <>  包含系统的文件 #include "":  包含总结编写的文件