了解HTML标签在各浏览器当中的默认样式,可以让我们了解,为什么会要写Reset.css,Reset.css当中要怎么写样式最合理。
试着思考下面的问题:

  • 为什么会有默认样式?
  • 每个浏览器的默认样式有什么不同?
  • Reset.css具体怎么写,每个浏览器展示的效果才会一致?

默认样式

这里说的默认样式其实是每个浏览器自己的默认样式,我们通常使用style或者link的形式应用的样式内容被成为“用户样式”。
浏览器加载完一个页面之后的工作流程大概如下:
1、转换
2、令牌化
3、词法分析
4、DOM树构建
5、CSSOM树构建
6、DOM树与CSSOM树合并后形成渲染树
7、通过布局计算每个对象显示的位置和大小
8、绘制页面

按照上面的流程,浏览器会查看文档当中是否有“用户样式”,如果没有就使用浏览器的默认样式,如果有就会用“用户样式”,就使用用户样式覆盖“浏览器默认样式”进行后面的渲染

隐藏元素

我们知道HTML标签当中的head,title,meta,link,style,script元素默认是不展示的,就是因为浏览器的默认样式当中定义了display:none属性。

head,meta,title,link,style,script{
display:none;
}

您可以通过定义如下代码在浏览器当中查看下效果

head{
display:block;
width:80px;
height:80px;
background:#f00;
}

block元素

块元素的特点:

  1. 每个块元素都是从新的一行开始(独占一行)
  2. 可以设置width,height,margin,border,padding
  3. 可以嵌套其它标签元素
  4. 默认块元素的宽度等于父元素的宽度
  5. 可以通过定义display:block,把元素设置为块元素

HTML标签当中,那些被称为块元素的标签之所以有块元素的属性,是因为浏览器默认给它定义了display:block
而不是因为是块元素才会有display:block属性。

所有定义了display:block的元素,都是块元素

html,
body,
p,
div,
layer,
article,aside,footer,header,hgroup,main,nav,section,
address,
blockquote,
figure,
center,
hr,
ol,ul,menu,dir,dd,dl,form,legend,fieldset,frameset,frame,details,summary
h1,h2,h3,h4,h5,h6{
display:block;
}

inline元素

行内元素的特点:

  1. 和其它元素在同一行
  2. width,height,margin-top,margin-bottom不可以控制元素的展现形式(定义无效)
  3. margin-left,margin-right,和padding可以定义
  4. 默认宽度是它所容纳内容的宽度
  5. 通过定义display:block,可以把行内元素设置为块元素

所有的元素默认都是行内元素,也就是display:inline

q,
map,
area,
output
{
display:inline;
}

display属性

html标签在浏览器当中是以那种布局形式展示,都是因为display属性的定义,display属性包含以下值:

基本值:    none | inline | block | list-item | inline-block
table系列: table | inline-table | table-caption | table-cell | table-row | table-row-group | table-column | table-columen-group | table-footer-group | table-header-group
css3新增: box | inline-box | flexbox | inline-flexbox | flex | inline-flex | run-in

基本值

  • none 隐藏元素
  • inline 设置为行内元素
  • block 设置为块元素
  • inline-block 设置为inline-block
  • list-item 设置为list-item

li标签默认定义的display:list-item,尝试定义如下的代码,在浏览器中查看:

    html
<div class="list">
<span class="item">1</span>
<span class="item">2</span>
<span class="item">3</span>
</div>
CSS
.item{
display:list-item;
}

table系列

  • table 块元素的表格
  • inline-table 行内元素的表格
  • table-caption 定义表格头
  • table-cell 表格单元格
  • table-row 表格单元行
  • table-row-group 单元行组
  • table-column 表格列
  • table-column-group 表格列组
  • table-footer-group 表格底
  • table-header-group 表格头

看下面一段代码

    <table>
<caption>年龄列表</caption>
<thead>
<tr>
<th>姓名</th>
<th>年龄</th>
</tr>
</thead>
<tfoot>
<tr>
<td>年龄综合</td>
<td>27</td>
</tr>
</tfoot>
<tbody>
<tr>
<td>张三</td>
<td>12</td>
</tr>
<tr>
<td>李四</td>
<td>15</td>
</tr>
</tbody>
</table>

当我们使用thead定义表头的时候,默认显示的样式就是因为thead标签定义了display:table-header-group;
同样,tfoot就是因为定义了display:table-footer-group;
caption 就是因为定义了display:table-caption;

关于table系列,我们简单了解两个问题:

  1. display:table和display:block的区别
  2. display:table-cell如何做多列布局

block和table的区别
1、block宽度默认撑满父元素
2、table宽度根据内容而定

table-cell的多列布局

    <div class="main">
<div class="left"></div>
<div class="middle"></div>
<div class="right"></div>
</div> .main{
width:500px;
display:table;
}
.left,.middle,.right{
display:table-cell;
height:100px;
}
.left{
width:20%;
background:#ff0;
}
.middle{
background:green;
}
.right{
width:10%;
background:red;
}

在线查看

CSS3系列,主要定义了弹性布局相关的内容

  • box 弹性伸缩盒版本1
  • inline-box 内联块弹性伸缩盒版本1
  • flexbox 弹性伸缩盒版本2
  • inline-flexbox内联块弹性伸缩盒版本2
  • flex 弹性伸缩盒版本3
  • inline-flex 内联块缩盒版本3
  • run-in 根据上下文定义对象是内联还是块级

弹性伸缩盒以后我们有机会详细聊聊,这里说说几个点
1、box和inline-box,flexbox和inline-flexbox,flex和inline-flex之间的差异
2、run-in是如何根据上下文作用的

第一个问题

在需要有固定宽度的情况下的弹性布局使用flex,
如果元素的宽度不固定,里面的标签还需要弹性布局的话,就是用inline-flex

我们通过以下代码来了解
flex布局;
inline-flex布局

第二个问题

这里有详细的解释

其它

块元素

行内元素

可变元素

文章七七八八,扯了很多东西,有点乱,让看官们受累了

参考

GitHub仓库

Chrom-blink
Chrom-webkit
Opera-10.51
Internet Explorer
HTML4
HTML5
浏览器渲染
解读默认样式

本文转载于猿2048:CSS系列——浏览器默认样式

CSS系列——浏览器默认样式的更多相关文章

  1. css清除浏览器默认样式

    css清除浏览器默认样式(代替 *{}) 将代码放入 css 文件,使用 link 引入. /* v2.0 | 20110126 http://meyerweb.com/eric/tools/css/ ...

  2. CSS之浏览器默认样式设置

    今天自己写css样式时,其中用到了<ul>标签,设置了一系列效果后运行,发现位置与设置有出入.chrome上打开检查项,发现<ul>标签的styles底部多了以下一段: ul, ...

  3. CSS之浏览器默认样式问题

    今天自己写css样式时,其中用到了<ul>标签,设置了一系列效果后运行,发现位置与设置有出入.chrome上打开检查项,发现<ul>标签的styles底部多了以下一段: ul, ...

  4. reset.css(重置浏览器默认样式)

    @charset "utf-8";html{background-color:#fff;color:#000;font-size:12px} body,ul,ol,dl,dd,h1 ...

  5. css知多少(4)——解读浏览器默认样式

    上一节<css知多少(3)——样式来源与层叠规则>介绍了样式的五种来源,咱们再通过一张图回顾一下. 对于上面的三层,咱们大概都比较熟悉了.下面的两层中,用户自定义样式一般也就是改一改字号大 ...

  6. css 框架——base.css,作用是重设浏览器默认样式和提供通用原子类。自己留存

    今天发下我自己的 css 框架——base.css,作用是重设浏览器默认样式和提供通用原子类. @charset "utf-8"; /*! * @名称:base.css * @功能 ...

  7. css知多少(4)——解读浏览器默认样式(转)

    css知多少(4)——解读浏览器默认样式   上一节<css知多少(3)——样式来源与层叠规则>介绍了样式的五种来源,咱们再通过一张图回顾一下. 对于上面的三层,咱们大概都比较熟悉了.下面 ...

  8. CSS 浏览器默认样式

    不要再说div天生就是block——这句话应该换成:浏览器默认样式天生规定了div是block——所以才导致了div是block!是默认样式规定的,不是浏览器的内核规定的. 没有设置block的元素, ...

  9. CSS改变浏览器默认滚动条样式

    前言 最近总是看到某网站滚动条不是浏览器默认样式,而是自定义样式   比如我博客的滚动条,自定义滚动条样式和hover前后的效果 顿时来了兴致和有一个疑问,这是怎么实现的呢? 解决   注:经测试,目 ...

随机推荐

  1. MATLAB神经网络应用设计【2】

    一.深度学习中经常看到epoch. iteration和batchsize,下面按自己的理解说说这三个的区别: (1)batchsize:批大小.在深度学习中,一般采用SGD训练,即每次训练在训练集中 ...

  2. git error: unable to create file Invalid argument

    git error: unable to create file xxxx  Invalid argument 原因: mac  上创建的文件名里有冒号,这在windows 上是不允许的. 解决方式: ...

  3. java 知识点梳理

    1.ArrayList与linkedList 区别 ArrayList 采用的是数组形式来保存对象的,这种方式将对象放在连续的位置中,所以最大的缺点就是插入删除时非常麻烦; 优点是查找比较快. Lin ...

  4. 程序设计基础·Java学习笔记·面向对象(上)

    Java程序设计基础之面向对象(上) (自适应学习进度而进行记录的笔记,希望有一些小小的用处吧(^∀^●)ノシ) (新人上路,望多指教,如有错误,望指正,万分感谢(o゚v゚)ノ) 目录 一.面向对象 ...

  5. python3生成一个含有20个随机数的列表,要求所有元素不相同,并且每个元素的值介于1到100之间

    import random alist = random.sample(range(1,101),20) #random.sample()生成不相同的随机数 print(alist)

  6. linux下yum无法安装lrzsz,Error: Failed to download metadata for repo ‘appstream‘: Cannot prepare internal

    镜像下载.域名解析.时间同步请点击阿里云开源镜像站 linux虚拟机上准备安装一下rz sz,执行yum命令后提示如下: [root@tony001 ~]# yum install lrzsz Cen ...

  7. 嵌入式无操作系统下管理内存和队列(类UCOS II思想)

    例子:存储日志,最多存128条,每条最大1MB. 内存方面 因为嵌入式不适合用动态内存,会产生碎片.这里我们用 u8 data[LOG_SIZE];开辟固定128MB的内存区,再对其分为128个1MB ...

  8. 领域驱动模型DDD(一)——服务拆分策略

    前言 领域驱动模型设计在业界也喊了几年口号了,但是对于很多"务实"的程序员来说,纸上谈"术"远比敲代码难得太多太多.本人能力有限,在拜读相关作品时既要隐忍书中晦 ...

  9. 如何移植sshserver到嵌入式平台

    ssh解释说明 SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立在应用层基础上的安全协议.SSH 是较可靠,专 ...

  10. macOS逆向-如何分析macOS软件

    目录 macOS逆向-如何分析macOS软件 0x00 前言: 0x01 分析环境搭建: 安装Clang 安装Radare2 关于HT Editor 什么是Radare2 Radare2的手动安装 测 ...