【前端】CSS

news/2024/11/29 8:59:48/

CSS Cascading Style Sheets 层叠样式表

能够对网页中的元素位置的排版进行像素级精确控制,实现美化页面的效果。

语法 

选择器 {声明}
  • 选择器决定针对谁修改
  • 声明决定修改什么
  • 声明的内容是键值对
  • 键值对间用 ; 隔开
  • 键与值间用 : 隔开

引入方式 

行内样式表

修改标签的 style 属性

<div style="color:green">想要生活过的去, 头上总得带点绿</div>

内部样式表

使用 style 标签嵌入 html 中

<style>div {text-align: center;}</style>

外部样式表

创建一个 css 文件

使用 link 标签引入 css

<link rel="stylesheet" href="路径">

选择器

基础选择器

标签选择器

能选出所有相同标签

不能差异化选择

body {}

类选择器

能选出一个或多个标签

根据需求选择,最灵活,最常用 

.类名 {}

id 选择器

能选出一个标签

一个 id 在一个 HTML 文件中,只能出现一次

#id名 {}

通配符选择器 

选择出所有标签

特殊情况下使用

* {}

复合选择器

后代选择器

元素 1 和 元素 2 要使用空格分割

元素 1 是父级,元素 2 是子级

只选择元素 2 ,不影响元素 1

元素1 元素2 {样式声明}

子类选择器

使用大于号分割

只选择儿子, 无法选择孙子元素

元素1>元素2 { 样式声明 }

并集选择器

通过 逗号 分割等多个元素

表示同时选中元素 1 和 元素 2

元素1, 
元素2 { 样式声明 }

伪类选择器

链接伪类选择器

a:link 选择未被访问过的链接
a:visited 选择已经被访问过的链接
a:hover 选择鼠标指针悬停上的链接
a:active 选择活动链接(鼠标按下了但是未弹起)

force 伪类选择器

input:focus 选取获取焦点的 input 表单元素

属性

字体属性

设置字体 

font-family: '字体名字';

大小

font-size: px;

粗细

  • 取值 [100, 900]
  • 700 == bold 加粗
  • 400 == normal 不加粗
font-weight: 400;
font-weight: normal;

文字样式

/* 设置倾斜 */
font-style: italic;/* 取消倾斜 */
font-style: normal;

文本属性

文本颜色

  • RGB 
  • R, G, B 分别使用一个字节表示
  • (8个比特位, 表示的范围是 0-255, 十六进制表示为 00-FF)
color: red; 颜色
color: #ff0000; 十六进制形式
color: rgb(255, 0, 0); RGB 方式

文本对齐

控制文字水平方向的对齐

  • left:左对齐
  • right:右对齐 
  • center:居中对齐
text-align: center;

文本装饰

  • underline 下划线
  • none 给 a 标签去掉下划线
  • overline 上划线
  • line-through 删除线
text-decoration: ;

文本缩进

  • 单位可以使用 px 或者 em
  • 通常使用 em 作为单位
  • 1 个 em 就是当前元素的文字大小
  • 缩进可以是负的
text-indent: ;

行高

行高指的是上下文本行之间的基线距离

  • 顶线
  • 中线
  • 基线
  • 底线

line-height: ;

背景属性

背景颜色

background-color: ;

背景图片

background-image: url(路径);

背景平铺

  • repeat 平铺
  • no-repeat 不平铺
  • repeat-x 水平平铺
  • repeat-y 垂直平铺 
background-repeat: repeat;

背景位置

  • 方位名词:top, left, right, bottom
  • 精确单位:坐标或者百分比,以盒子左上角为原点
  • 混合单位:同时包含方位名词和精确单位
background-position: x y;

背景尺寸

background-size: px px; 宽度 高度
background-size: %; 相对于父级元素的百分比
background-size: cover; 整张背景图片覆盖盒子
background-size: contain; 使盒子的背景图片的尺寸最大化

圆角矩形

border-radius: px;

圆形

div {width: 200px;height: 200px;border: 2px solid green;border-radius: 100px;/* 或者用 50% 表示宽度的一半 */border-radius: 50%;
}

胶囊

div {width: 200px;height: 100px;border: 2px solid green;border-radius: 50px;
}

显示模式

显示模式有很多种,最主要的就是块级元素的显示模式行内元素的显示模式

行内元素和块级元素的区别

  • 块级元素独占一行, 行内元素不独占一行
  • 块级元素可以设置宽高, 行内元素不能设置宽高.
  • 块级元素四个方向都能设置内外边距, 行内元素垂直方向不能设置 

改变显示模式

使用 display 属性可以修改元素的显示模式

  • 可以把 div 等变成行内元素
  • 可以把 a , span 等变成块级元素
display: block 改成块级元素 [常用]display: inline 改成行内元素 [很少用]display: inline-block 改成行内块元素

盒模型

每一个 HTML 元素就相当于是一个盒子

这个盒子这四个部分构成

  • 外边距 margin
  • 边框 border
  • 内边距 padding
  • 内容 content

border 边框

属性

  • 粗细: border-width
  • 样式: border-style 默认无边框 solid 实线边框 dashed 虚线边框 dotted 点线边框
  • 颜色: border-color
div {width: 500px;height: 250px;border-width: 10px;border-style: solid;border-color: green;
}

简写

/* 无顺序要求 */
/* 一般 */
/* 粗细 样式 颜色 */
border: 1px solid red;

加上边框会使盒子变大

当我们在网页中修改边框的时候

很可能会影响到网页中其他元素的布局

将 box-sizing 的值修改为 border-box 即可

* {box-sizing: border-box;
}

padding 内边距

内容与边框间的空间

padding-top
padding-bottom
padding-left
padding-right
padding: 5px; 表示四个方向都是 5px
padding: 5px 10px; 表示上下内边距 5px, 左右内边距为 10px
padding: 5px 10px 20px; 表示上边距 5px, 左右内边距为 10px, 下内边距为 20px
padding: 5px 10px 20px 30px; 表示 上5px, 右10px, 下20px, 左30px (顺时针)

margin 外边距

两个盒子边框间的距离

已最大的外边距为准

margin-top
margin-bottom
margin-left
margin-right
margin: 10px; // 四个方向都设置
margin: 10px 20px; // 上下为 10, 左右 20
margin: 10px 20px 30px; // 上 10, 左右 20, 下 30
margin: 10px 20px 30px 40px; // 上 10, 右 20, 下 30, 左 40

块级元素水平居中

/* 第一种写法 */
margin-left: auto; 
margin-right: auto;/* 第二种写法 */
margin: auto;/* 第三种写法 */
margin: 0 auto;

垂直居中, 不能使用 "上下 margin 为 auto " 的方式

去除浏览器的默认样式

部分浏览器会自己给我们的盒子加上内外边距

为了我们写出来的网页能适配各种各样的浏览器

我们在开始写网页的时候需将浏览器给的默认样式先去除

* {marign: 0;padding: 0;
}

弹性布局

display: flex;
  • 被设置为 display:flex 属性的元素, 称为 flex container 弹性容器
  • 它的所有子元素立刻称为了该容器的成员, 称为 flex item 弹性元素
  • flex item 可以沿纵向排列和横向排列, 排列的方向称为 flex direction 弹性方向(主轴)

主轴 侧轴

一般默认

主轴为 横向

侧轴为 纵向

justify-content

内容对齐

决定 flex item 在主轴方向上的排列方式

justify-content: 效果
flex-start左对齐
flex-end右对齐
center居中对齐
space-between

居中对齐    每个 item 间有空隙

space-around居中对齐    每个 item 间有空隙    item 与 container 间也有空隙

align-items

校准元素

决定 flex item 在侧轴方向上的排列方式

align-items: 效果
flex-start上对齐
flex-end下对齐
center居中对齐

http://www.ppmy.cn/news/354541.html

相关文章

Ehcache官网教程中文版

官网链接&#xff1a;https://www.ehcache.org/ 官网英文文档链接&#xff1a;https://www.ehcache.org/documentation/3.8/getting-started.html Maven 依赖&#xff1a; <dependency><groupId>org.ehcache</groupId><artifactId>ehcache</artif…

【合集丨值得收藏】Node.js合集(完结)

Node.js合集 前言目录一、Node.js安装与配置(详细步骤&#xff0c;值得收藏)二、初始Node.js(简短)三、走进Node.js(fs文件系统模块)四、走进Node.js(path路径模块)五、【值得收藏】走进Node.js之将自己电脑摇身变成一台web服务器(http模块)六、走进Node.js之模块化七、走进Nod…

前端特效——复杂下雪,雪花纷飞(纯css)

效果&#xff1a; 原理&#xff1a; 因为是用的纯css&#xff0c;所以为了实现很多个雪花&#xff0c;我们就需要创建200个div&#xff08; 数量适量多即可&#xff09; 然后先设置雪花div的共同属性&#xff1a;雪花的背景图片是雪花&#xff0c;给初始大小width: 10px;heig…

夹道之樱

传送门已损坏 题目描述 在一座山上&#xff0c;有n个亭子&#xff0c;连接这这n个亭子的&#xff0c;是m条可以双向行走的步道。每条步道的两旁都栽种着两行樱花树&#xff0c;然而由于光照、土质和打理频率差异&#xff0c;每条步道的美观程度并不一样&#xff0c;第i条步道连…

前端特效CSS样式樱花

下面直接上代码: <!doctype html> <html lang"en"> <head> <meta charset"UTF-8"> <title>cloth</title> <style> body { padding:0; margin:0; overflow:hidden; height: 600px; } c…

JS : 网页樱花飘落特效

JS <script> //妯辫姳var stop, staticx;var img new Image();img.src "…

樱花飘雪

你想问问“樱花屋”的事情&#xff1f;   现在就要动身到那里去吗&#xff1f;你说想成为樱花屋的顾客&#xff1f;   啊&#xff0c;不成不成。那是相当怪的商店&#xff0c;除了山里人以外&#xff0c;谁也不让进去。你还是回去吧&#xff0c;你这城里人一眼就能看出来&a…

《我们的战国》樱雪丸

我对日本了解甚少&#xff0c;这本书写的不错&#xff0c;浅显易懂&#xff0c;语言诙谐。 书中的人名较多&#xff0c;建议在阅读时画画逻辑图&#xff0c;这样人物之间的关系就比较清晰。一休&#xff0c;北条早云和斋藤道三都给人印象深刻&#xff0c;日本的战国&#xff0c…