CSS笔记(二)

  • CSS 列表
  • CSS Table(表格)
  • CSS 盒子模型
  • CSS Border(边框)
  • CSS 轮廓(outline)属性
  • CSS margin(外边距)
  • CSS padding(填充)

CSS 列表

CSS 列表属性作用如下:

  • 设置不同的列表项标记为有序列表
  • 设置不同的列表项标记为无序列表
  • 设置列表项标记为图像

1. 列表

在 HTML中,有两种类型的列表:

  • 无序列表 ul - 列表项标记用特殊图形(如小黑点、小方框等)
  • 有序列表 ol - 列表项的标记有数字或字母
    使用 CSS,可以列出进一步的样式,并可用图像作列表项标记。

2. 不同的列表项标记

list-style-type属性是指定列表项标记的类型。

ul.a {list-style-type: circle;}
ul.b {list-style-type: square;}


ol.c {list-style-type: upper-roman;}
ol.d {list-style-type: lower-alpha;}


3. 作为列表项标记的图像

要指定列表项标记的图像,使用列表样式图像属性,如:

ul
{
    list-style-image: url(‘sqpurple.gif’);
}


4. 列表 - 简写属性

在单个属性中可以指定所有的列表属性。这就是所谓的简写属性。
为列表使用简写属性,列表样式属性设置如下:

ul
{
    list-style: square url(“sqpurple.gif”);
}

要按顺序设置如下属性:

  • list-style-type
  • list-style-position
  • list-style-image

如果上述值丢失一个,其余仍在指定的顺序,就没关系。


5. 移除默认设置

list-style-type:none 属性可以用于移除小标记。
默认情况下列表 <ul> 或 <ol> 还设置了内边距和外边距,可使用 margin:0 和 padding:0 来移除:

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}


6. 所有的CSS列表属性

属性 描述
list-style 简写属性。用于把所有用于列表的属性设置于一个声明中
list-style-image 将图像设置为列表项标志
list-style-position 设置列表中列表项标志的位置
list-style-type 设置列表项标志的类型

CSS 表格

使用 CSS 可以使 HTML 表格更美观。


1. 表格边框

指定CSS表格边框,使用border属性。
下面的例子指定了一个表格的Th和TD元素的黑色边框:

table, th, td
{
    border: 1px solid black;
}

请注意,在上面的例子中的表格有双边框。这是因为表、 th 和 td元素都有独立的边界。
为了显示一个表的单个边框,使用 border-collapse属性。


2. 折叠边框

border-collapse 属性设置表格的边框是否被折叠成一个单一的边框或隔开:

table
{
    border-collapse: collapse;
}
table, th, td
{
    border: 1px solid black;
}


3. 表格宽度和高度

Width和height属性定义表格的宽度和高度。
下面的例子是设置100%的宽度,50像素的th元素的高度的表格:

table
{
    width:100%;
}
th
{
    height:50px;
}


4. 表格文字对齐

包括表格中的文本对齐和垂直对齐属性。

text-align 属性设置水平对齐方式,向左,右,或中心:

td
{
    text-align:right;
}

vertical-align 属性设置垂直对齐方式,比如顶部,底部或中间:

td
{
    height:50px;
    vertical-align:bottom;
}


5. 表格填充

修改td和th元素 padding 属性,控制边框和表格内容之间的间距:

td
{
    padding:15px;
}


6. 表格颜色

指定边框的颜色、th元素的文本和背景颜色:

table, td, th
{
    border:1px solid green;
}
th
{
    background-color:green;
    color:white;
}


CSS 盒子模型

所有HTML元素可以看作盒子,在CSS中,”box model”这一术语是用来设计和布局时使用。
CSS盒模型封装周围的HTML元素,它包括:边距,边框,填充,和实际内容。
盒模型允许我们在其它元素和周围元素边框之间的空间放置元素。
下面的图片说明了盒子模型(Box Model):

盒模型示意图

  • Margin(外边距) - 清除边框外的区域,外边距是透明的。
  • Border(边框) - 围绕在内边距和内容外的边框。
  • Padding(内边距) - 清除内容周围的区域,内边距是透明的。
  • Content(内容) - 盒子的内容,显示文本和图像。

当指定一个 CSS 元素的宽度和高度属性时,你只是设置内容区域的宽度和高度。要知道,完整大小的元素,你还必须添加内边距,边框和外边距。
试想一下,你只有 250 像素的空间。让总宽度为 250 像素的元素可以如下设置:

div {
    width: 220px;
    padding: 10px;
    border: 5px solid gray;
    margin: 0;
}


最终元素的总宽度计算公式是这样的:
总元素的宽度 = 宽度 + 左填充 + 右填充 + 左边框 + 右边框 + 左边距 + 右边距

元素的总高度最终计算公式是这样的:
总元素的高度 = 高度 + 顶部填充 + 底部填充 + 上边框 + 下边框 + 上边距 + 下边距


CSS Border(边框)

CSS边框属性允许你指定一个元素边框的样式颜色

在四边都有边框


红色底部边框


圆角边框


左侧边框带宽度,颜色为蓝色


1. 边框样式

边框样式属性指定要显示什么样的边界。
border-style 属性用来定义边框的样式

none: 默认无边框

dotted: 定义一个点线边框

dashed: 定义一个虚线边框

solid: 定义实线边框

double: 定义两个边框。 两个边框的宽度和 border-width 的值相同

groove: 定义3D沟槽边框。效果取决于边框的颜色值

ridge: 定义3D脊边框。效果取决于边框的颜色值

inset:定义一个3D的嵌入边框。效果取决于边框的颜色值

outset: 定义一个3D突出边框。 效果取决于边框的颜色值


2. 边框宽度

您可以通过 border-width 属性为边框指定宽度。
为边框指定宽度有两种方法:可以指定长度值,比如 2px 或 0.1em(单位为 px, pt, cm, em 等),或者使用 3 个关键字之一,它们分别是 thick 、medium(默认) 和 thin。
注:CSS 没有定义 3 个关键字的具体宽度,所以一个用户可能把 thick 、medium 和 thin 分别设置为等于 5px、3px 和 2px,而另一个用户则分别设置为 3px、2px 和 1px。

p.one
{
    border-style:solid;
    border-width:5px;
}
p.two
{
    border-style:solid;
    border-width:medium;
}


3. 边框-单独设置各边

在CSS中,可以指定不同的侧面不同的边框:

p
{
    border-top-style:dotted;
    border-right-style:solid;
    border-bottom-style:dotted;
    border-left-style:solid;
}


4. border-style 属性

可以设置一个单一属性设置四个边框。
border-style属性可以有1-4个值:

border-style:dotted solid double dashed;

  • 上边框是 dotted
  • 右边框是 solid
  • 底边框是 double
  • 左边框是 dashed

border-style:dotted solid double;

  • 上边框是 dotted
  • 左、右边框是 solid
  • 底边框是 double

border-style:dotted solid;

  • 上、底边框是 dotted
  • 右、左边框是 solid

border-style:dotted;

  • 四面边框是 dotted

上面的例子用了border-style。然而,它也可以和border-width 、 border-color一起使用。


5. 边框-简写属性

上面的例子用了很多属性来设置边框,也可以在一个属性中设置边框。
你可以在 border 属性中设置:

  • border-width
  • border-style
  • border-color

对他们的先后顺序没有要求,如:

border:5px solid red;


6. CSS 边框属性

属性 描述
border 简写属性,用于把针对四个边的属性设置在一个声明
border-style 用于设置元素所有边框的样式,或者单独地为各边设置边框样式
border-width 简写属性,用于为元素的所有边框设置宽度,或者单独地为各边边框设置宽度
border-color 简写属性,设置元素的所有边框中可见部分的颜色,或为 4 个边分别设置颜色
border-bottom 简写属性,用于把下边框的所有属性设置到一个声明中
border-bottom-color 设置元素的下边框的颜色
border-bottom-style 设置元素的下边框的样式
border-bottom-width 设置元素的下边框的宽度
border-left 简写属性,用于把左边框的所有属性设置到一个声明中
border-left-color 设置元素的左边框的颜色
border-left-style 设置元素的左边框的样式
border-left-width 设置元素的左边框的宽度
border-right 简写属性,用于把右边框的所有属性设置到一个声明中
border-right-color 设置元素的右边框的颜色
border-right-style 设置元素的右边框的样式
border-right-width 设置元素的右边框的宽度
border-top 简写属性,用于把上边框的所有属性设置到一个声明中
border-top-color 设置元素的上边框的颜色
border-top-style 设置元素的上边框的样式
border-top-width 设置元素的上边框的宽度

CSS 轮廓(outline)

  • 轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
  • 轮廓(outline)属性指定元素轮廓的样式、颜色和宽度。

轮廓(outline)是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
outline 属性规定元素轮廓的样式、颜色和宽度。

轮廓示意图

所有CSS 轮廓属性如下:

属性 说明
outline 在一个声明中设置所有的轮廓属性 outline-color
outline-style
outline-width
inherit
outline-color 设置轮廓的颜色 color-name
hex-number
rgb-number
invert
inherit
outline-style 设置轮廓的样式 none
dotted
dashed
solid
double
groove
ridge
inset
outset
inherit
outline-width 设置轮廓的宽度 thin
medium
thick
length
inherit

CSS margin(外边距)

CSS margin(外边距)属性定义元素周围的空间。

margin 清除周围的(外边框)元素区域。margin 没有背景颜色,是完全透明的。
margin 可以单独改变元素的上,下,左,右边距,也可以一次改变所有的属性。

margin示意图


1. 可能的值

Margin可以使用负值,起到重叠的效果。

说明
auto 设置浏览器边距
length 定义一个固定的margin(使用px,pt,em等)
% 定义一个使用百分比的边距

2. Margin - 单边外边距属性

在CSS中,它可以指定不同的侧面不同的边距:

margin-top:100px;
margin-bottom:100px;
margin-right:50px;
margin-left:50px;


3. Margin - 简写属性

为了缩短代码,有可能使用一个属性中margin指定的所有边距属性。这就是所谓的简写属性。
所有边距属性的简写属性是 margin :

margin属性可以有一到四个值。

margin:25px 50px 75px 100px;

  • 上边距为25px
  • 右边距为50px
  • 下边距为75px
  • 左边距为100px

margin:25px 50px 75px;

  • 上边距为25px
  • 左右边距为50px
  • 下边距为75px

margin:25px 50px;

  • 上下边距为25px
  • 左右边距为50px

margin:25px;

  • 所有的4个边距都是25px

4. 所有的CSS边距属性

属性 描述
margin 简写属性。在一个声明中设置所有外边距属性
margin-bottom 设置元素的下外边距
margin-left 设置元素的左外边距
margin-right 设置元素的右外边距
margin-top 设置元素的上外边距

CSS padding(填充)

CSS padding(填充)是一个简写属性,定义元素边框与元素内容之间的空间,即上下左右的内边距。

当元素的 padding(填充)内边距被清除时,所释放的区域将会受到元素背景颜色的填充。
单独使用 padding 属性可以改变上下左右的填充。

padding示意图

说明
length 定义一个固定的填充(像素, pt, em,等)
% 使用百分比值定义一个填充

1. 填充- 单边内边距属性

在CSS中,它可以指定不同的侧面不同的填充。如:

padding-top:25px;
padding-bottom:25px;
padding-right:50px;
padding-left:50px;


2. 填充 - 简写属性

为了缩短代码,它可以在一个属性中指定的所有填充属性。
这就是所谓的简写属性。所有的填充属性的简写属性是 padding :

Padding属性,可以有一到四个值。

padding:25px 50px 75px 100px;

  • 上填充为25px
  • 右填充为50px
  • 下填充为75px
  • 左填充为100px

padding:25px 50px 75px;

  • 上填充为25px
  • 左右填充为50px
  • 下填充为75px

padding:25px 50px;

  • 上下填充为25px
  • 左右填充为50px

padding:25px;

  • 所有的填充都是25px

3. 所有的CSS填充属性

属性 说明
padding 使用简写属性设置在一个声明中的所有填充属性
padding-bottom 设置元素的底部填充
padding-left 设置元素的左部填充
padding-right 设置元素的右部填充
padding-top 设置元素的顶部填充
Author

Lamber

Posted on

2022-01-01

Updated on

2022-01-05

Licensed under