首页 > 其他分享 >HTML 行内元素 与 块级元素

HTML 行内元素 与 块级元素

时间:2022-10-12 15:06:18浏览次数:59  
标签:块级 行内 元素 120 width HTML overflow


行内元素和块级元素

行内元素一般是内容的容器,而块级元素一般是其他容器的容器。一般情况下,行内元素只能包含内容或者其它行内元素,宽度和长度依据内容而定,不可以设置,可以和其它元素和平共处于一行;而块级元素可以包含行内元素和其它块级元素,且占据父元素的整个空间,可以设置 width 和 height 属性,浏览器通常会在块级元素前后另起一个新行。

因此,行内元素适合显示具体内容,而块级元素适合做布局。常用的行内和块级元素如下:

级别

元素

行内元素

a,b,strong,span,img,label,button,input,select,textarea

块级元素

header,form,ul,ol,table,article,div,hr,aside,figure,canvas,video,audio,footer

之所以说“一般情况下”,是因为元素的级别不是一成不变的,浏览器是按照规范规定元素默认的级别,但是可以通过“display”属性改变其级别。

常用的 display 值

常用的 display 可能的值如下:


说明

inline

以行内元素行为展示

block

以块级元素行为展示

inline-block

行内元素和块级元素特性兼而有之,既不会占满父元素,又可以设置width和height属性

table

以表格的形式展示

table-cell

以表格单元格的形式展示

table-row

以表格行的形式展示

table-column

以表格列的形式展示

flex

CSS3 新增,虽然处于CR阶段,但是很多现代浏览器已经支持无前缀的该特性,IE从11开始部分支持。类似块级元素,但是可以用于制作自适应布局

inline-flex

类似行内元素,但是可以用于制作自适应布局

grid

CSS3 新增,目前处于“实验阶段(Experimental)”,只是得到了IE11和edge的部分支持

行内元素 和 块级元素 盒模型区别

行内元素尺寸由内含的内容决定,盒模型中 padding, border 与块级元素并无差异,都是标准的盒模型,但是 margin 却只有水平方向的值,垂直方向并没有起作用。

块级元素当没有明确指定 width 和 height 值时,块级元素尺寸由内容确定,当指定了 width 和 height 的值时,内容超出块级元素的尺寸就会溢出,这时块级元素要呈现什么行为要看其 overflow 的值,下面会提到。块级元素的 padding, border 和标准的盒模型一致,但是如果 ​​width + padding + border + 指定的margin​​ 小于其父元素的宽度时,浏览器会通过补margin 来填满整行。

块级元素 与 overflow

块级元素当没有明确指定 width 和 height 值时,块级元素尺寸由内容确定,当指定了 width 和 height 的值时,内容超出规定的尺寸就会溢出,元素的尺寸并不会随着内容改变。这时候使用 overflow 可以指定内容超出时的行为,当然, overflow 只对块级元素起作用,指定当内容超出块级容器的时候,块级元素该如何处理内容的显示。overflow 可能的值如下表:


说明

visible

默认值,如果内容超出容器尺寸,不做任何处理

hidden

超出的内容被截断并隐藏

scroll

无论内容是否超出,总是显示滚动条。可以控制只显示一个方向的滚动条,这时应该设置 overflow-x 和 overflow-y

auto

内容没有超出时,不显示滚动条;内容超出时,显示滚动条,且如果只有一个方向超出,那么只显示该方向上的滚动条

举个例子,html 结构是三个 DIV 元素,css 样式一样,只有 overflow 的值不同:

​​<div class='block'>
blockblockblock
</div>

<div class='block-hidden'>
blockblockblock
</div>

<div class='block-auto'>
blockblockblock<
/div>​​​
​​.block{
height: 40px;
width: 100px;
font-size: 30px;
padding: 10px;
border: 6px solid rgb(120, 120, 120);
margin: 20px;
background-color: rgb(255, 0, 0);
}

.block-hidden{
height: 40px;
width: 100px;
font-size: 30px;
padding: 10px;
border: 6px solid rgb(120, 120, 120);
margin: 20px;
background-color: rgb(255, 0, 0);
overflow: hidden;
}

.block-auto{
height: 40px;
width: 100px;
font-size: 30px;
padding: 10px;
border: 6px solid rgb(120, 120, 120);
margin: 20px;
background-color: rgb(255, 0, 0);
overflow: auto;
}​​

最终,面对三种设置,效果是这样的。

HTML 行内元素 与 块级元素_块级元素

总结

文章总结了行内元素和块级元素的区别,每个元素都可以通过 display 来设置行内还是块级显示,inline 和 block 是两种显示模型,浏览器对每个元素都要采用一种模型来呈现元素,上面我们提到的行内元素和块级元素分组,其实并不是它们天生就应该这样,而是浏览器按照规范指定了默认值,因此即使我们没有指定这些属性,那些元素仍然会按照其所属类别渲染呈现。通过display 可以改变元素对应的渲染呈现模型,也就是盒模型。当块级元素的内容超出容器时,使用 overflow 属性来指定块级元素的行为

标签:块级,行内,元素,120,width,HTML,overflow
From: https://blog.51cto.com/u_15826214/5750753

相关文章

  • HTML5之input标签的新type属性
    新type属性介绍首先让我们来看一张表HTML5中的type.png其中标有`红色5`的代表`HTML5`中推出的测试代码:<!DOCTYPEhtml><htmllang="en"><head><metacharset="......
  • htmlToPdf
    第一步:安装html2canvas,我用npm或者yarnnpmaddhtml2canvas第二步:安装jspdfnpminstalljspdf--save第三步,写一个ts文件//导出页面为PDF格式/*eslint-disable*/......
  • 代码随想录算法训练营第一天 |704. 二分查找, 17. 移除元素
    算法训练营第一天,训练内容是二分查找和双指针。704.二分查找``` classSolution{  publicintsearch(int[]nums,inttarget){    intn=nums.le......
  • 【算法训练营day1】LeetCode704. 二分查找 LeetCode27. 移除元素
    【算法训练营day1】LeetCode704.二分查找LeetCode27.移除元素LeetCode704.二分查找题目链接:704.二分查找初次尝试看到题目标题是二分查找,所以尝试使用二分查找的......
  • leetcode 219. Contains Duplicate II 存在重复元素 II(简单)
    一、题目大意给你一个整数数组nums和一个整数k,判断数组中是否存在两个不同的索引i和j,满足nums[i]==nums[j]且abs(i-j)<=k。如果存在,返回true;否则,返......
  • JS 获取指定元素滚动条
    获取后台数据接口,当数据无的时候,可以移除滚动监听mounted(){//监听滚动window.addEventListener("scroll",this.getScroll,true);},......
  • 练习:集合元素处理(传统方式)与练习:集合元素处理(Stream方式)
    练习:集合元素处理(传统方式)现在有两个ArrayList集合存储队伍当中的多个成员姓名,要求使用传统的for循环(或增强for循环)依次进行以下若干操作步骤1.第一个队伍只要名字为......
  • HTML基础知识与常用标签
    HTML目录HTML1.HTML文件的基础结构2.HTML标签2.1标签基础2.2常用标签meta标签实体(转义字符)标题标签超链接标签列表标签img标签音频标签表格标签iframe框架标签表单......
  • CSS - 01 CSS和HTML的结合方式
    1.CSS和HTML的结合方式内联样式/行内样式在标签内部,通过style属性设置元素的样式key:valuevalue;(由于内联样式的复用性非常差,所以开发中基本不使用内联样式)<divst......
  • 使用html+css初步完成小兔鲜儿案例
    最近在跟着黑马课程学习搭建小兔鲜儿项目,现阶段主要用HTML+CSS完成静态页面的展示,因此为了加深使用css样式的记忆和学习搭建项目的一些小技巧,此文留下了小笔记。  ......