前端:css

前端:css

1.css介绍

1.1 CSS

​ (Cascading Style Sheet,层叠样式表)定义如何显示HTML元素,给HTML设置样式,让它更加美观。

   当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染)。

1.2css语法

​  每个CSS样式由两个组成部分:选择器和声明。声明又包括属性和属性值。每个声明之后用分号结束。

image-20220106164852505

2.css的几种引入方式

​ 2.1方法一内部式

嵌入式是将CSS样式集中写在网页的标签对的标签对中

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    方法一
    <style>
        div {
            background-color: red;
            height: 100px;
            width: 100px;
        }
    </style>
</head>
<body>
    <div >

    </div>
</body>
</html>

​ 2.2方法二:内敛样式

行内式是在标记的style属性中设定CSS样式。不推荐大规模使用。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
<!--    方法一-->
<!--    <style>-->
<!--        div {-->
<!--            background-color: red;-->
<!--            height: 100px;-->
<!--            width: 100px;-->
<!--        }-->
    </style>
</head>
<body>
    <div style="background-color: blue; height: 200px; width: 200px;">

    </div>
</body>
</html>

​ 2.3方法三:外部文件引入

外部样式就是将css写在一个单独的文件中,然后在页面进行引入即可。推荐使用此方式。

新建一个css文件命名为test

div{
    background-color: green;
    height: 100px;
    width: 100px;
}

在html界面应用css文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <link rel="stylesheet" href="test.css">

    </style>
</head>
<body>

<div>

</div>
</body>
</html>

3.css基本选择器

3.1元素选择器

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
<!--    元素选择器 div标签的都变成红色-->
    <style>
        div{
            color: red;
        }

    </style>
</head>
<body>
    <div>
    alex
    </div>
    <span>cookie</span>

    <div>大胖</div>
</body>
</html>

image-20220106190049526

3.2id选择器

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
<!--    元素选择器-->
    <style>

        #大胖{
            color: green;
        }

    </style>
</head>
<body>
    <div>
    alex
    </div>
    <span>cookie</span>

    <div id="大胖">大胖</div>
</body>
</html>

image-20220106190943313

3.3类选择器

 id不能重复,如果想给多个p标签同时添加一个css样式怎么办?挨个添加id属性吗?并且,如果是不同的标签,但是他们的css样式要一样,怎么办?使用类选择器!!!

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
<!--    元素选择器-->
    <style>
        .c1{
            color: aqua;
        }

    </style>
</head>
<body>
    <div class="c1">
    alex
    </div>
    <span>cookie</span>

    <div class="c1">大胖</div>
</body>
</html>

image-20220106191442435

3.4通用选择器

* {  *表示所有的标签
  color: white;
}

4.css组合选择器

4.1后代选择器(子子孙孙)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div a{   <!-- 找到div里面的所有的a标签 -->
            color: red;
        }

    </style>
</head>
<body>
    <div>
        <a href="">百度</a>
        <div>
        <a href="">京东</a>
        </div>
    </div>

     <a href="">小米</a>

</body>
</html>

image-20220106194400272

4.2儿子选择器(只找儿子)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div>a{
            color: red;
        }

    </style>
</head>
<body>
    <div>
        <a href="">百度</a>
        <p>
        <a href="">京东</a>
        </p>
    </div>

     <p href="">小米</p>

</body>
</html>

image-20220106194554597

4.3 毗邻选择器

/*选择所有紧接着<div>元素之后的标签元素*/
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div+a{
            color: red;
        }

    </style>
</head>
<body>
    <div>
        <a href="">百度</a>
        <p>
        <a href="">京东</a>
        </p>
    </div>

     <a href="">小米</a>
     <a href="">华为</a>

</body>
</html>

image-20220106194738478

4.4弟弟选择器

/*i1后面所有的兄弟p标签*/
#i1~p {
  border: 2px solid royalblue;
}
找到的是所有的同级的标签的后面的标签

image-20220106195447440

5.属性选择器

/*找到所有title属性以hello开头的元素*/
[title^="hello"] {
  color: red;
}

/*找到所有title属性以hello结尾的元素*/
[title$="hello"] {
  color: yellow;
}

/*找到所有title属性中包含(字符串包含)hello的元素*/
[title*="hello"] {
  color: red;
}
css
/*找到所有title属性(有多个值或值以空格分割)中有一个值为hello的元素:*/
[title~="hello"] {
  color: green;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div[title]{
            color: red;
        }
        input[type=text] {
            background-color: blue;
        }

    </style>
</head>
<body>
<input type="text">
<input type="password">
    <div title="xx">
        div1
    </div>
    <div>
        div2
    </div>

</body>
</html>

image-20220106200447197

5.1.分组

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div,p{
            color: red;
        }
        input[type=text] {
            background-color: blue;
        }

    </style>
</head>
<body>
<input type="text">
<input type="password">
    <div title="xx">
        div1
    </div>
    <p>
        div2
    </p>

</body>
</html>

image-20220106200806437

5.2. 嵌套

  多种选择器可以混合起来使用,比如:.c1类内部所有p标签设置字体颜色为红色。

.c1 p {
  color: red;
}

6.伪类选择器

比较特殊,CSS3版本新加的特性

  可以根据标签的不同状态再进行进一步的区分,比如一个a标签,点击前,点击时,点击后有不同的三个状态。

/* 未访问的链接 */
a:link {
  color: #FF0000
}

/* 已访问的链接 */
a:visited {
  color: #00FF00
} 

/* 鼠标移动到链接上 */  这个用的比较多
a:hover {
  color: #FF00FF
} 

/* 选定的链接 */ 就是鼠标点下去还没有抬起来的那个瞬间,可以让它变颜色
a:active {
  color: #0000FF
}

/*input输入框获取焦点时样式*/
input:focus {   #input默认的有个样式,鼠标点进去的时候,input框会变浅蓝色的那么个感觉
  #outline: none;
  background-color: #eee; #框里面的背景色}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        a:link{
            color: green;
        }

        a:visited{
            color: green;
        }

        a:hover{
            color: yellow;
        }

    </style>
</head>
<body>

<a href="https://www.jd.com">京东</a>

<a href="http://www.baidu.com">百度</a>
</body>
</html>

image-20220106204228833

7.伪元素选择器

通过css来造标签,不推荐使用

  first-letter

  常用的给首字母设置特殊样式:

#将p标签中的文本的第一个字变颜色变大小
p:first-letter { 
  font-size: 48px;
  color: red;
}

before

/*在每个<p>元素之前插入内容*/
p:before {
  content:"*";
  color:red;
}

after

/*在每个<p>元素之后插入内容*/
p:after {
  content:"[?]";
  color:blue;
} 

上面的这些前后添加的文本内容在页面上是无法选中的,正常的标签或者文字是可以选中的。

  before和after多用于清除浮动。

8.选择器的优先级

8.1css继承

继承是CSS的一个主要特征,它是依赖于祖先-后代的关系的。继承是一种机制,它允许样式不仅可以应用于某个特定的元素,还可以应用于它的后代。例如一个body定义了的字体颜色值也会应用到段落的文本中。

body {
  color: red;
}

此时页面上所有标签都会继承body的字体颜色。然而CSS继承性的权重是非常低的,是比普通元素的权重还要低的,他的权重是0。

  我们只要给对应的标签设置字体颜色就可覆盖掉它继承的样式。

p {
  color: green;
}

​ 此外,继承是CSS重要的一部分,我们甚至不用去考虑它为什么能够这样,但CSS继承也是有限制的。有一些属性不能被继承,如:border, margin, padding, background等。

8.2选择器的优先级

​ 我们上面学了很多的选择器,也就是说在一个HTML页面中有很多种方式找到一个元素并且为其设置样式,那浏览器根据什么来决定应该应用哪个样式呢?

image-20220106205659296

​ 其他的权重:但是有一点说一下,就是上面那个权重计算永不进位的意思是:我们看上面知道class的权重是10,但是即便是11个class相加起来大于id的100权重,也还是id生效,也就是说,不会进位,class组合起来也无法超过id的权重

image-20220106222342445

  除此之外还可以通过添加 !important方式来强制让样式生效,不讲道理的操作,但并不推荐使用。因为如果过多的使用!important会使样式文件混乱不易维护,使用方法:

image-20220106222403519

万不得已可以使用!important

9.css相关属性

9.1高度和宽度

  width属性可以为元素设置宽度。

  height属性可以为元素设置高度。

  块级标签才能设置宽度,内联标签的宽度由内容来决定。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小康之家</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            background-color: pink;
        }

    </style>
</head>
<body>
    <div class="c1">
        我是div1标签
    </div>

    <span>我是span标签</span>
</body>
</html>

image-20220106223646608

补充:a标签不会继承css属性,必须要指定a标签

9.2字体属性

  • 文字字体:font-family可以把多个字体名称作为一个“回退”系统来保存。如果浏览器不支持第一个字体,则会尝试下一个。浏览器会使用它可识别的第一个值。

    body {
      font-family: "Microsoft Yahei", "微软雅黑", "Arial", sans-serif
    }
    
  • 字体大小

    p {
      font-size: 14px;字体默认大小为16px
    }
    
  •  如果设置成inherit表示继承父元素的字体大小值。

    字重(字体粗细)

       font-weight用来设置字体的字重(粗细)。

描述
normal 默认值,标准粗细
bold 粗体
bolder 更粗
lighter 更细
100~900 设置具体粗细,400等同于normal,而700等同于bold
inherit 继承父元素字体的粗细值
  • 文本颜色

 颜色属性被用来设置文字的颜色。

  颜色是通过CSS最经常的指定:

  1. 十六进制值 - 如: FF0000 #前两位是表示红,中间两位表示绿,后面两位表示蓝,F是最高级别,0表示最低级别(无色)

  2. 一个RGB值 - 如: RGB(255,0,0) #红绿蓝就是RGB的意思,第一个参数是红,最高255,最低0

  3. 颜色的名称 - 如: red

  还有rgba(255,0,0,0.3),第四个值为alpha, 指定了色彩的透明度/不透明度,它的范围为0.0到1.0之间。

  • 文字属性

    文字对齐

       text-align 属性规定元素中的文本的水平对齐方式。(letter-spacing)

    image-20220107151227775

      

  • 常用的为去掉a标签默认的自划线:

    a {
      text-decoration: none;
    }
    
描述
none 默认。定义标准的文本。
underline 定义文本下的一条线。
overline 定义文本上的一条线。
line-through 定义穿过文本下的一条线。
inherit 继承父元素的text-decoration属性的值。

 注意:line-height与height设置值相同时,字体会垂直居中。;

  • 首行缩进

​ 将段落的第一行缩进 32像素:

p {
  text-indent: 32px; #首行缩进两个字符,因为我记得一个字在页面上的默认大小为16px
}

9.3背景属性

/*背景颜色*/background-color: red;
/*背景图片*/
background-image: url('1.jpg');  #url里面是图片路径,如果和你的html文件在一个目录下,使用这种相对路径就行了,来个葫芦娃图片试一下
background-repeat: no-repeat; 
/* 背景重复 repeat(默认):背景图片沿着x轴和y轴重复平铺,铺满整个包裹它的标签 repeat-x:背景图片只在水平方向上平铺 repeat-y:背景图片只在垂直方向上平铺 no-repeat:背景图片不平铺*/

/*背景位置*/
background-position: right top;/*background-position: 200px 200px;*/ #200px 200px 是距离父级标签的左边和上边的距离,以前大家都用雪碧图,就是将很多的网页上需要的小图片组合成一个大图,用这个图中哪个位置的小图片,就通过这个参数来调整,看下面的示例操作,现在很少用这个

简写方式
background:#ffffff url('1.png') no-repeat right top;

默认放满拼图界面image-20220106224534414

  • 如果只想显示一个使用以下参数:repeat-x/y填充x/y轴

image-20220107151805548

image-20220107155318260

  • 一个有趣的例子:鼠标滚动但是背景不动,就是最近发现的,很多电商都在这么搞,你们看过这种效果没有。下面是我模仿着写的一个小例子
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>滚动背景图示例</title>
    <style>
        * {
            margin: 0;
        }
        .box {
            width: 100%;
            height: 500px;
            background: url("https://static001.infoq.cn/resource/image/de/c2/de6050d8a8060197af15f161985f42c2.jpg") no-repeat center center;
            background-attachment: fixed;
        }
        .d1 {
            height: 500px;
            background-color: tomato;
        }
        .d2 {
            height: 500px;
            background-color: steelblue;
        }
        .d3 {
            height: 500px;
            background-color: mediumorchid;
        }
    </style>
</head>
<body>
    <div class="d1"></div>
    <div class="box"></div>
    <div class="d2"></div>
    <div class="d3"></div>
</body>
</html>

image-20220107161026991

image-20220107160926318

9.4边框

  边框属性

  1. border-width 宽度

  2. border-style 样式

  3. border-color 颜色

#i1 {
  border-width: 2px;  
  border-style: solid;
  border-color: red;
}

通常使用简写方式:

#i1 {
  border: 2px solid red;
}

边框样式

描述
none 无边框。
dotted 点状虚线边框。
dashed 矩形虚线边框。
solid 实线边框。

​ 除了可以统一设置边框外还可以单独为某一个边框设置样式,如下所示:

#i1 {
  border-top-style:dotted;
  border-top-color: red;
  border-right-style:solid;
  border-bottom-style:dotted;
  border-left-style:none;
}

单独设置一下左边的边框:

border-left:10px solid red

   img

  只显示左边的边框:

9.5 border-radius

 用这个属性能实现圆角边框的效果。将border-radius设置为长或高的一半即可得到一个圆形。

    img

    

  img

    效果: img

    img

    img

    还可在调试窗口调整颜色来测试(调试窗口:页面上右键--检查,或者f12)

 img

    调整好之后,把调整后的值复制到我们的css属性里面就行了

    还可以通过hover来设置鼠标移动上去变颜色:

    img

    img

      img

      你会看到之前的background-color有了一个横线,这是不生效的效果,因为你查看的hover的样式

      还可以看到class

      img

      img

      把对勾去了,这个class的样式就不显示了

      通过调试窗口还可以玩一个神奇的东西:document.body.contentEditable=true

      img

      不用ps就能够改了:注意昂,只能改当前页面的显示内容,改不了真实的值,并且页面一刷新,这个指令就失效了,需要重新输入

      

9.6display属性

  用于控制HTML元素的显示效果。

意义
display:"none" HTML文档中元素存在,但是在浏览器中不显示。一般用于配合JavaScript代码使用。
display:"block" 默认占满整个页面宽度,如果设置了指定宽度,则会用margin填充剩下的部分。
display:"inline" 按行内元素显示,此时再设置元素的width、height、margin-top、margin-bottom和float属性都不会有什么影响。
display:"inline-block" 使元素同时具有行内元素和块级元素的特点。

  display:"none"与visibility:hidden的区别:

  visibility:hidden: 可以隐藏某个元素,但隐藏的元素仍需占用与未隐藏之前一样的空间。也就是说,该元素虽然被隐藏了,但仍然会影响布局。

  display:none: 可以隐藏某个元素,且隐藏的元素不会占用任何空间。也就是说,该元素不但被隐藏了,而且该元素原本占用的空间也会从页面布局中消失。

    教大家一些创建标签时的简写方法:

    img

    看效果:

    img

    img

    或者简写:

    img

    然后按一下tab键:

    img

    然后看div里面套一个a标签

    img

    然后一回车

    img

    img

    img

    这些都是编辑器帮你提供的快捷方式。有兴趣的同学可以去研究研究,有好多,一个nb的前端工程师,写一个页面非常快速

    img

    img

    在加一个$符号:

    img

    img

    img

    按delete删除:

    一下就删除了三个了:

    img

 注意一点昂:块级标签不管你设置的宽度是多少,都会占用你整个页面宽度的空间,看下面

    img

    img

    img

   然后我们看一下display的效果inline-block,高度宽度还可以设置,包含内联和块级标签的属性

    img

    img

    还可以通过display:block将内联标签改为块级标签的效果

    img

    看效果:

    img

    

    img

    看效果    

    img

    img

    img

    不占用位置,也不显示

10.盒子模型

在css里面,每个标签可以称为一个盒子模型,看下面的图:

  1.margin: 外边距:用于控制元素与元素之间的距离;margin的最基本用途就是控制元素周围空间的间隔,从视觉角度上达到相互隔开的目的。

  2.padding: 内边距:用于控制内容与边框之间的距离;

  3.Border(边框): 围绕在内边距和内容外的边框。

  4.Content(内容): 盒子的内容,显示文本和图像。

    看图吧:img

10.1margin外边距

.margin-test {
  margin-top:5px;
  margin-right:10px;
  margin-bottom:15px;
  margin-left:20px;
}

   img

    所以在写css样式的时候,都会先写一个

    img

    意思是说,body的上下左右的margin都设置为0.

    在看一个,如果将上下两个标签都设置了margin是什么效果

两个情况:

​ 1.垂直方向如果上下两个标签都设置了margin外边距,那么取两则最大的值

​ 2.水平方向:两个标签都设置了外边距,取两者的边距之和

    img

    img

    

    推荐使用简写:

.margin-test {
  margin: 5px 10px 15px 20px;
}

    顺序:上右下左

    常见居中:

.mycenter {
  margin: 0 auto;  #上下0像素,左右自适应,居中的效果
}如果你写的是三个:margin: 10px 20px 10px;意思是上为10,左右为20,下为10

10.2padding内填充

.padding-test {
  padding-top: 5px;
  padding-right: 10px;
  padding-bottom: 15px;
  padding-left: 20px;
}

推荐使用简写:

.padding-test {
  padding: 5px 10px 15px 20px;
}

 顺序:上右下左

  补充padding的常用简写方式:

  • 提供一个,用于四边;
  • 提供两个,第一个用于上-下,第二个用于左-右;
  • 如果提供三个,第一个用于上,第二个用于左-右,第三个用于下;
  • 提供四个参数值,将按上-右-下-左的顺序作用于四边;

10.3float

  在 CSS 中,任何元素都可以浮动。最开始出现浮动这个东西是为了什么呢,记不记得一个word文档里面,插入图片的时候,有一个文字环绕的效果啊:

    img

  最开始浮动这个东西是想要做上面这种效果用的,现在多数用来做网页布局的。你记不记得很多的网站都是左边一个菜单栏,右边一堆的其他内容啊

    img

    你看昂:我们如果这样写

    img

    看效果:

    img

    那怎么让绿色的这个跑到红色的左边呢?

    img

    

    img

    上面是浮动的一个最简单的用法,但是浮动有一个副作用,看:

    重新创建一个htnl文件,我们写上下面的内容

    img

    css样式:

    img


    img

    怎么让下面这个粉色的跑到右边去啊

    img

    

刷新看看效果:父级标签塌陷

    img

  发现是不是有问题啊,两个红色的设置了一个往左浮动一个往右浮动,c3那个标签没有设置浮动之后,发现红色的两个虽然浮动了,但是粉色的这个跑上去了,两个红色的压在这个粉色的标签上了。

  先看这个问题昂:在给c2的div标签加上浮动之前是下面这样的效果:

    img

  我并没有给c1那个div标签设置高度,但是你发现c1这个div标签是有高度的,这是因为里面两个c2div我设置了高度了,这两个div将c1这个div标签撑起来了。当我们加上浮动之后,你再看这个c1的div标签的高度:发现c1这个div的高度没有了,显示的高度是1.99,是因为我给它设置了边框,上下边框加起来正好2px,这里显示了个约等的值,别在意昂

    img

  这就看到了浮动的副作用,浮动起来以后脱离了你整个页面文档,然后两个c1的div标签,一个往左靠,一个往右靠,无法撑起自己的父级标签了,也就是那个c1的div标签,那么粉色的c3那个标签就上去了。影响了我们页面的整个布局。

  我们不想让粉色的这个标签顶上去怎么办,看一下c1这个标签的子标签的高度(内边距+外边距+边框宽度+标签高度),然后给c1这个父标签的高度设置成这个值,当然是可以的,但是如果两个子标签的高度不相等呢,你按照哪一个来算高度啊,并且将来这样的标签要是很多怎么办,没法算对不对,所以我们一般不用这种方法来解决浮动的问题,看下面我们要学的clear,清除浮动。

  浮动元素会生成一个块级框,而不论它本身是何种元素。

  关于浮动的两个特点:

  • 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。
  • 由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。

三种取值

  left:向左浮动

  right:向右浮动

  none:默认值,不浮动

clear

  clear属性规定元素的哪一侧不允许其他浮动元素。

描述
left 在左侧不允许浮动元素。
right 在右侧不允许浮动元素。
both 在左右两侧均不允许浮动元素。
none 默认值。允许浮动元素出现在两侧。
inherit 规定应该从父元素继承 clear 属性的值。

  注意:clear属性只会对自身起作用,而不会影响其他元素。按照我们上面那个例子的意思就是说,我们可以给粉色的那个c3属性的div标签设置一个clear:both,意思是说,这个标签的左右都不能有浮动的标签,那么它只能跑到两个浮动的c2div标签的下面,但是一般我们都会再c2和c3的中间加一个别的标签,给这个标签设置一个clear属性,并且高度设置为0,或者不给高度,因为浮动的标签是你自己c1里面的,所以你要自己解决,才能撑起你自己的高度,并且再用其他的标签的时候,我们就不需要再考虑浮动的问题了,直接写自己的样式就可以了,不然你每次加其他的标签都要去看看上面的标签有没有浮动的啊,对不对。

    接着看上面这个示例,如果我们这样设置:

    img

    img

    img

    这样粉色的这个标签就上不去了

10.4清除浮动

    浮动的副作用(父标签塌陷问题),所以要清除浮动

    主要有三种方式:

  • 固定高度 就是我们刚才的示例,在父标签里面加一个其他的标签
  • 伪元素清除法 css来解决
  • overflow:hidden 给塌陷的父级标签设置这个属性就可以清除浮动。

    伪元素清除法(使用较多):

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

 我们通过微元素清除法来清除一下浮动:

  

    img

    img

    效果是一样的:

    img

    一般业内约定成俗,都把这个清除浮动的class属性命名为clearfix,而不是cc,如果你在别的网页看到了这个clearfix,这个一定是用来清除浮动的。

   总结一下:为什么要有浮动啊,是想做页面布局,但是浮动有副作用,父级标签塌陷,所以要想办法去掉这个副作用,使用了clear来清除浮动带来的副作用,我们当然也可以通过设置标签为inline-block来实现这种布局效果,但是把一个块级标签变成一个类似内敛标签的感觉,不好操控,容易混乱,所以一般都用浮动来进行布局。

10.5overflow溢出属性

  先看下面的例子

描述
visible 默认值。内容不会被修剪,会呈现在元素框之外。
hidden 内容会被修剪,并且其余内容是不可见的。
scroll 内容会被修剪,但是浏览器会显示滚动条以便查看其余的内容。
auto 如果内容被修剪,则浏览器会显示滚动条以便查看其余的内容。
inherit 规定应该从父元素继承 overflow 属性的值。
  • overflow(水平和垂直均设置)
  • overflow-x(设置水平方向,只出现x轴的滚动条)
  • overflow-y(设置垂直方向,只出现y轴的滚动条)

  举个例子:

    比如我们在一个标签里面写了一堆的文字,然后把标签的高度和宽度设置的比较小的时候,文字就溢出了:

    img

    img

    然后我们就可以设置一下,如果文字溢出了,溢出的部分怎么办,设置一个overflow为hidden:

    img

    再看效果,溢出的文字就不显示了。

    img

    如果设置成overflow为scroll,就会出现滚动条,我们改动一个下标签的高度和宽度昂,要不然不好看出效果:

    img

    看效果:

    img    

10.6圆形头像示例

<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>圆形的头像示例</title>
<style>
* {
margin: 0;
padding: 0;
background-color: #eeeeee;
}
.header-img {
width: 150px; #如果这个高度和宽度比图片的像素小怎么办,图片显示不全啊,因为用户上传的头像没准多大像素的,就需要设置下面哈格.header-mg>img,里面写上max-width:100%了
height: 150px;
border: 3px solid white;
border-radius: 50%; #圆形的边框
overflow: hidden; #溢出的内容隐藏
}
.header-img>img {
max-width: 100%; #相当于将图片的大小设置为父级标签的大小来显示了,因为用户上传的头像的像素我们是不知道的,就让它按照父级标签的大小来,就能放下整个头像了,就不会出现头像显示不全的问题了
    #直接写width:100%就行,上面写max-width的意思是如果图片大于咱们设置的标签高宽的时候,就按照父级标签的大小来,比父级标签的高宽小的时候,就不需要按照父级标签的大小来了,了解一下就行了

}
</style>
</head>
<body>

<div class="header-img">
<img src="https://q1mi.github.io/Blog/asset/img/head_img.jpg" alt="">
</div>

</body>
</html>

  img

  下面我们来学习定位:也是用来布局的,一般用来做一些小的布局,例如小米商城:

    img

    还有网站右上角这个东西:

    img

    这些小范围的布局一般都是定位做的,大范围的布局一般都是用float来做的

    img

    下面我们来看看定位的用法

10.7定位(position)

  static(无定位,咱就不说了,主要看相对和绝对定位)

  static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。

1.relative(相对定位)

  相对定位是相对于该元素在文档流中的原始位置,即以自己原始位置左上角为参照物。有趣的是,即使设定了元素的相对定位以及偏移值,元素还占有着原来的位置,即占据文档流空间。对象遵循正常文档流,所以不会出现像浮动那种父级标签塌陷的副作用,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。往上移动🔝-100px(注意是负值)或者bottom:-100px(负值),往左移动:left:-100px(也是负值)或者right:-100px,往下移动:bottom:100px(正值)或者top:100px(正值),往右移动:right:100px(正值)或者left:100px。大家记住一点昂,凡是标签要进行移动,不管是float还是relative还是线面的absolute,都是按照元素自己的左上角进行计算的

  注意:position:relative的一个主要用法:方便下面要学的绝对定位元素找到参照物。可以将元素设置成relative,不设置任何的top、left、right、bottom等,它还是它原来的位置

image-20220107225632235

2.absolute(绝对定位)

  定义:设置为绝对定位的元素框从文档流完全删除,也会有父级标签塌陷的问题,并相对于最近的已定位祖先元素定位,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(即body元素)。元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

  重点:如果父级设置了position属性,例如position:relative;,那么子元素就会以父级的左上角为原始点进行定位。这样能很好的解决自适应网站的标签偏离问题,即父级为自适应的,那我子元素就设置position:absolute;父元素设置position:relative;,然后Top、Right、Bottom、Left用百分比宽度表示。

  另外,对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

image-20220107225708473

  fixed(固定)不管页面怎么动,都在整个屏幕的某个位置

  fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性 定义。 注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。但是 relative 却可以。因为它原本所占的空间仍然占据文档流。

image-20220107230219745

  在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。

  示例代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>返回顶部示例</title>
<style>
* {
margin: 0;
}

.d1 {
height: 1000px;
background-color: #eeee;
}

.scrollTop {
background-color: darkgrey;
padding: 10px;
text-align: center; #水平居中
position: fixed;
right: 10px; #距离窗口右边框的距离
bottom: 20px; #距离窗口下边框的距离
/*height:20px;
    line-height:20;当line-height等于height的值的时候,就能实现一个文本居中的效果 */
}
</style>
</head>
<body>
<div class="d1">111</div>
<div class="scrollTop">返回顶部</div>
</body>
</html>

image-20220107230812328

10.8z-index:控制层级(一般用于模态对话框)

#i2 {
  z-index: 999;
}

 设置对象的层叠顺序。一般用在模态对话框上:

      img

 那么谁在上面显示,谁被压在下面的呢,就是通过这个z-index来设置的。

  1. z-index 值表示谁压着谁,数值大的压盖住数值小的,
  2. 只有定位了的元素,才能有z-index,也就是说,不管相对定位,绝对定位,固定定位,都可以使用z-index,而浮动元素float不能使用z-index
  3. z-index值没有单位,就是一个正整数,默认的z-index值为0如果大家都没有z-index值,或者z-index值一样,那么谁写在HTML后面,谁在上面压着别人,定位了元素,永远压住没有定位的元素。
  4. 从父现象:父亲怂了,儿子再牛逼也没用


#自定义的一个模态对话框示例代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>自定义模态框</title>
<style>
.cover {
background-color: rgba(0,0,0,0.65); #rgba的最后一个参数就是透明度的意思,所以如果我们这样写,就不需要写下面那个opcity了,但是这个只表示的背景颜色的透明度,opcity是标签的透明度及标签的内容(包括里面的文字)及标签下面的子标签的透明度
position: fixed;
top: 0;
right: 0; top\right\bottom\left都设置为0,意思就是全屏,这个标签把全屏都覆盖了
bottom: 0;
left: 0;
z-index: 998;
#opcity:0.4; #设置元素的透明度
}

.modal {
background-color: white;
position: fixed;
width: 600px;
height: 400px;
left: 50%; #设置了left50%top50%,你就会发现,你这个标签的左上角相对于页面的左面是50%,上面是50%,所以我们还要移动窗口,往左移动标签宽度的一半,往上移动高度的一半就行了。就是下面的margin设置
top: 50%;
margin: -200px 0 0 -300px; #左下右上,别忘了,往左移动要负值,往上移动要负值,因为它的移动是按照自己标签的左上角来移动的。
z-index: 1000;
}
</style>
</head>
<body>

<div class="cover"></div>
<div class="modal"></div>
</body>
</html>


自定义模态框示例

来再教大家一个pycharm的用法,自定义快捷键:

    img

      然后点击apply和ok:

      img

    在到html页面中也一个hya:

      img

    就看到了这些文字:

      img

    在pycharm的使用秘籍里面都有昂,自己去学吧~~~,网上一搜pycharm的使用,就有

10.9opacity

 用来定义透明效果。取值范围是0~1,0是完全透明,1是完全不透明。

综合示例

  顶部导航菜单方法一



<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>li标签的float示例</title>
<style>
/*清除浏览器默认外边距和内填充*/
* {
margin: 0;
padding: 0;
}
a {
text-decoration: none; /*去除a标签默认的下划线*/
}

.nav {
background-color: black;
height: 40px;
width: 100%;
position: fixed;
top: 0;
}

ul {
list-style-type: none; /*删除列表默认的圆点样式*/
margin: 0; /*删除列表默认的外边距*/
padding: 0; /*删除列表默认的内填充*/
}
/*li元素向左浮动*/
li {
float: left;
}

li > a {
display: block; /*让链接显示为块级标签*/
padding: 0 15px; /*设置左右各15像素的填充*/
color: #b0b0b0; /*设置字体颜色*/
line-height: 40px; /*设置行高*/
}
/*鼠标移上去颜色变白*/
li > a:hover {
color: #fff;
}

/*清除浮动 解决父级塌陷问题*/
.clearfix:after {
content: "";
display: block;
clear: both;
}
</style>
</head>
<body>
<!-- 顶部导航栏 开始 -->
<div class="nav">
<ul class="clearfix">
<li><a href="">玉米商城</a></li>
<li><a href="">MIUI</a></li>
<li><a href="">ioT</a></li>
<li><a href="">云服务</a></li>
<li><a href="">水滴</a></li>
<li><a href="">金融</a></li>
<li><a href="">优品</a></li>
</ul>
</div>
<!-- 顶部导航栏 结束 -->
</body>
</html>


顶部导航菜单示例

  上面的导航栏的效果:

  img

  顶部导航菜单方法二:

<!DOCTYPE HTML>
<html leng="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>li标签的float示例</title>
    <style>
        /*清除浏览器默认外边距和内填充*/
        body {
        margin: 0;
        padding: 0;
        }

        .title{
            background-color: #333;
            height: 40px;
        }


        .title .title-content a {
            text-decoration: none; /*去除a标签默认的下划线*/
            color: #b0b0b0;
            font-size: 12px;

        }

        .title .title-content{
            width: 90%;   /*  父类标签宽度的90% */
            margin-left: 5%;     /*父类标签宽度的5%*/
            height: 40px;
            line-height: 40px;
        }

        .title .title-content span{
            color: #424242;
        }

        .title .title-content .title-content-left{
            float: left;
            height: 39px;
            line-height: 39px;
        }

        .title .title-content .title-content-right{
            float: right;
            height: 40px;
            line-height: 40px;
        }



    </style>
</head>
<body>
<!-- 顶部导航栏 开始 -->
<div class="title">
    <div class="title-content">
        <div class="title-content-left">
            <a href="">玉米商城</a><span>|</span>
            <a href="">MIUI</a><span>|</span>
            <a href="">ioT</a><span>|</span>
            <a href="">云服务</a><span>|</span>
            <a href="">水滴</a><span>|</span>
            <a href="">金融</a><span>|</span>
            <a href="">优品</a><span>|</span>

        </div>
        <div class="title-content-right">
            <ur class="clearfix">
                <a href="">登录</a><span>|</span>
                <a href="">注册</a><span>|</span>
                <a href="">消息通知</a><span>|</span>
                <a href="">购物车</a><span>|</span>

            </ur>

        </div>
    </div>

</div>

<!-- 顶部导航栏 结束 -->
</body>
</html>

image-20220108194720189

将来我们在写一个页面的时候,首先写页面的整体结构,就是布局,大块先搞出来,再大块的基础上来来写小块,然后一级一级的这么写。看下面的小米商城的示例,按照红框--黄框--子框--蓝框来看整个布局:

  img

  产品经理需求-->UI(视觉、交互等各种UI)将这些页面做成图片(包括里面的文字大小图片大小等都给你准备好,标的很清楚)-->前端工程师(通过前端代码来实现UI的页面)-->后端工程师(写提供数据、处理数据的逻辑)-->DBA管理数据

最后给大家一个css只做动画效果的方式:鼠标移动到标签上的时候,出现动态效果和阴影的效果:

[复制代码](javascript:void(0)😉

复制代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        /*给标签加上鼠标移动上去的一些效果*/
        #test{
            height: 200px;
            border: 1px solid black;

        }
        #test:hover{
            box-shadow: 0 5px 10px;  /*给标签加阴影的效果,参数1是水平方向的阴影,参数2的5px是垂直方向上的阴影,参数3是阴影的范围*/
            transform: translate3d(3px,-2px,0); /*鼠标移动上去之后有个标签往上台的效果,三个参数是:x轴,y轴,z轴,现在的效果是y轴方向往上移动2px,x轴往右移动3px*/
            transition:all,.2s linear; /*这个的意思是所有的新样式改变,在0.2秒内慢慢的显示出来*/
        }

    </style>
</head>
<body>

<div id="test"></div>

</body>
</html>

复制代码

[复制代码](javascript:void(0)😉

 有一个做网页的时候的一个图片示例的网址:https://dummyimage.com/

  如果在这个网址后面输入下面的内容:

    img

    一回车,你就看到下面的这个图:

    img

  注意一点:

  当你们写了新的css样式的时候,如果自己调试的时候发现页面上刷新不出来怎么办,是因为浏览器有可能还在使用你之前的样式,教大家一个方法,让你写的新的css生效的方法:

  f12打开浏览器调试窗口,找到下面这个设置:

      img

    

   img

然后刷新页面就可以了。

10.10锚点

设置
	<a name='top'>顶部</a>
	<a id='top'>顶部</a>
触发点:
	<a href='#top'></a>
posted @   凡间小王  阅读(124)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示