【Web技术】CSS基础入门

简介

层叠样式表

(英文全称:Cascading Style Sheets)是一种用来表现HTMLXML结构化文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。

html和css是解释性语言,没有编译产物

功能:(松耦合原则)

  1. 改变浏览器的默认显示风格
  2. 内容内容和显示样式分离
  3. 可以重用样式表,方便网站维护
  4. 同一网页内容,使用不同的CSS可显示不同的效果

结构化文档

什么是结构化文档?它有什么优势?

html是结构化文档,word文档不是结构化的文档;结构化文档由标题章节段落逻辑结构组成。

数据表也是结构化的文档;计算机处理结构化的文档更方便,因为它的结构是固定的;

CSS 语法

选择符 {规则}

选择符:页面的哪一些部分套用样式

规则(声明块):规则由属性名和属性组成;被选中的部分按什么规则显示

选择符 {
    
    属性名1:属性值1;属性名2:属性值2;}
h1{
    
    color:red;font-size:14px;}

应用CSS样式的3中方式

行内样式

行内样式(也称内联样式)可用于为单个元素应用唯一的样式。有效范围是单个元素

<html 标签名称 style="属性名1:属性值1;属性名2:属性值2;...">

内部样式

内部样式是在 head 部分的 <style> 元素中进行定义。有效范围是整个HTML文件

<style type="">
    选择符{
    
    color:green;
    font-family:华文彩云;
    }
</style>

CSS选择符由3种:

HTML标签、class、id

1.HTML标签选择符

如何使用 css 控制表格样式

没有使用任何样式的表格html效果:

<table border=1 cellspacing=0>
		
	</table>	

image-20220331151115025

使用css对表格样式进行设置,效果如下:

<head>
	<title>这是一个课程表</title>
	<style>
	table{
    
    
	border-collapse:collapse;//边框折叠
	border:1px solid #000000;//边框的粗细,实线,颜色
	}
	table td{
    
    
	text-align:center;//文字中间对齐
	border:1px solid #000000;
	width:120px;
	height:50px;
	}
	table th{
    
    
	border:1px solid #000000;
	background-color:#e0e0e0;
	}
	
	</style>
</head>

image-20220331155658395

2.class选择符(可以单独使用也可以结合标签使用)

单独使用

定义:.类名{}

使用:<标签 class=类名>

结合标签使用

定义:标签.类名{}

使用:<标签 class=类名1 类名2 ...>(可以使用多个类)

伪类(特殊的选择符)

3.id选择符

单独使用

定义:#id名{}

使用:<标签 ID=id名>

结合标签使用

定义:标签 #类名{...}

使用:<标签 ID=类名>

外部样式表

将页面的css代码单独的写在一个文件里,通过引用来使用

每张 HTML 页面必须在 head 部分的 <link> 元素内包含对外部样式表文件的引用

嵌入式样式表

<style type="text/css"
	@import url("外部样式表的文件名");
</style>

链接外部样式表

<link type="text/css " rel=stylesheet href="外部样式表的文件名">

层叠顺序

对于某一个HTML标签,若有多层样式,不冲突则叠加

当为某个 HTML 元素指定了多个样式时,会使用哪种样式呢?

页面中的所有样式将按照以下规则“层叠”为新的“虚拟”样式表,其中第一优先级最高:

  1. 行内样式(在 HTML 元素中)
  2. 外部和内部样式表(在 head 部分)
  3. 浏览器默认样式

因此,行内样式具有最高优先级,并且将覆盖外部和内部样式以及浏览器默认样式。

页面定位

position:可以把页面元素精确定位,有3种方式

  1. 绝对位置:absolute
  2. 相对位置:relative
  3. 静态位置:static

小例子:如何实现广告小窗口?

用绝对布局将广告位设置在页面的右下角:

div{
    
    
	border-style:solid;
	width:200px;
	height:200px;
	position:absolute;
	right:0px;
	bottom:0px;
	}

image-20220331190840024

left:页面元素的左边距

top:页面元素的顶边距

width:元素的宽度

height:元素的高度

z-index:设计页面的层次关系,元素在三位坐标z轴上的位置

CSS3扩展

圆角属性

语法:

border-radius:圆角的像素值

例子:

#circle{
    
    
	background:#e0e0e0;
	border-radius:15px;
	width=200px;
	height=200px;
	}
<div id=circle>招租广告位
	</div>

image-20220331193821661

线性渐变

创建线性渐变,必须定义至少两个色标。设置渐变的起点和方向(或角度)以及渐变效果。

语法:

background-image: linear-gradient(direction, color-stop1, color-stop2, ...);

例子:

#color{
    
    
	height:200px;
	background-image:linear-gradient(red,yellow);//默认向下渐变
	}

image-20220331201031660

我们还可以指定方向,从左上到右下渐变

#color{
    
    
	height:200px;
	background-image:linear-gradient(to bottom right,red,yellow);
	}

image-20220331201223331

我们还可以增加透明度在渐变的效果里

如需添加透明度,需要使用 rgba() 函数来定义色标。 rgba() 函数中的最后一个参数可以是 0 到 1 的值,它定义颜色的透明度:0 表示全透明,1 表示全彩色(无透明)。颜色的rgb值可以在网上找,我一般使用一款叫snipaste的截图软件附带的取色功能获取rgb值

#grad {
    
    
  background-image: linear-gradient(to right, rgba(77,144,254,0), rgba(77,144,254,1));
}

)]

我们还可以增加透明度在渐变的效果里

如需添加透明度,需要使用 rgba() 函数来定义色标。 rgba() 函数中的最后一个参数可以是 0 到 1 的值,它定义颜色的透明度:0 表示全透明,1 表示全彩色(无透明)。颜色的rgb值可以在网上找,我一般使用一款叫snipaste的截图软件附带的取色功能获取rgb值

#grad {
    
    
  background-image: linear-gradient(to right, rgba(77,144,254,0), rgba(77,144,254,1));
}

image-20220331201656536

猜你喜欢

转载自blog.csdn.net/weixin_53463734/article/details/123886921