【海贼王航海日志:前端技术探索】CSS你了解多少?(三)

简介: 【海贼王航海日志:前端技术探索】CSS你了解多少?(三)

1 -> 浏览器调试工具——查看CSS属性

1.1 -> 打开浏览器

有两种方式可以打开浏览器调试工具。

  • 直接按F12键。
  • 鼠标右键页面 => 检查元素。

1.2 -> 标签页含义

console查看控制台。

source查看源码+断点调试。

network查看前后端交互过程。

application查看浏览器提供的一些扩展功能(本地存储等)。

Performance、Memory、Security、Lighthouse暂时不使用,先不深究。

1.3 -> elements标签页使用

ctrl + 滚轮进行缩放,ctrl + 0恢复原始大小。

使用左上角箭头选中元素。

右侧可以查看当前元素的属性,包括引入的类。

右侧可以修改选中元素的css属性。例如颜色,可以点击颜色图标,弹出颜色选择器,修改颜色。例如字体大小,可以使用方向键来微调数值。

此处的修改不会影响代码,刷新就还原了。

如果CSS样式写错了,也会在这里有提示。(黄色感叹号)

2 -> 元素的显示模式

在 CSS 中,HTML 的标签的显示模式有很多。

此处重点介绍两个:

  • 块级元素。
  • 行内元素。

2.1 -> 块级元素

常见的元素:

h1 - h6

p

div

ul

ol

li

...

特点:

  • 独占一行。
  • 高度,宽度,内外边距,行高都可以控制。
  • 宽度默认是父级元素宽度的100%(和父元素一样宽)。
  • 是一个容器(盒子),里面可以放行内和块级元素。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    .demo1 .parent {
        width: 500px;
        height: 500px;
        background-color: rgb(26, 227, 26);
    }
    .demo1 .child {
        /* 不写 width, 默认和父元素一样宽 */
        /* 不写 height, 默认为 0 (看不到了) */
        height: 200px;
        background-color: skyblue;
    }
    </style>
 
</head>
 
<body>
    
    <div class="demo1">
        <div class="parent">
            <div class="child">
                王路飞
            </div>
            <div class="child">
                刘索隆
            </div>
        </div>
    </div>
 
</body>
</html>

展示结果:

注意:

  • 文字类的元素内不能使用块级元素。
  • p标签主要用于存放文字,内部不能放块级元素,尤其是div。
<body>
    
    <p>
        <div>王路飞</div>
    </p>
 
</body>

2.2 -> 行内元素/内联元素

常见的元素:


a

strong

b

em

i

del

s

ins

u

span

...

特点:

  • 不独占一行,一行可以显示多个。
  • 设置高度,宽度,行高无效。
  • 左右外边距有效(上下无效)。内边距有效。
  • 默认宽度就是本身的内容。
  • 行内元素只能容纳文本和其他行内元素,不能放块级元素。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    .demo2 span {
        width: 200px;
        height: 200px;
        background-color: skyblue;
    }
    </style>
 
</head>
 
<body>
 
    <div class="demo2">
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
    
</body>
</html>

展示结果:

注意:

  • a标签中不能再放a标签(虽然不报错,但是最好不要这么做)。
  • a标签里可以放块级元素,但是更建议先把a转换成块级元素。

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

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

2.3 -> 改变显示模式

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

可以把div等变成行内元素,也可以把a,span等变成块级元素。

  • display: block改成块级元素。
  • display: inline改成行内元素。
  • display: inline-block改成行内块元素。

3 -> 盒模型

每一个HTML元素就相当于是一个矩形的 "盒子"。

这个盒子由这几个部分构成:

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

3.1 -> 边框

基础属性

  • 粗细:border-width
  • 样式:border-style,默认没边框。solid实线边框、dashed虚线边框、dotted点线边框。
  • 颜色:border-color。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    
    <div>
        路飞太郎
    </div>
 
</body>
</html>

style.css

div {
    width: 500px;
    height: 250px;
    border-width: 10px;
    border-style: solid;
    border-color: skyblue;
}

展示结果:

支持简写,没有顺序要求。

border: 1px solid red;

可以改四个方向的任意边框。

border-top/bottom/left/right

以下的代码只给上边框设为红色,其余为蓝色。

利用到的层叠性,就近原则的生效。

border: 1px solid blue;

border-top: red;

边框会撑大盒子

可以看到,width、height是500 * 250,而最终整个盒子大小是520 * 270。边框10个像素相当于扩大了大小。

买房子时:

建筑面积 = 套内面试 + 公摊面试(电梯间)。

套内面积 = 使用面积 + 墙占据的空间。

蓝色区域就是 "使用面积", 绿色区域就是 "套内面积"。


通过box-sizing属性可以修改浏览器的行为,使边框不再撑大盒子。

* 为通配符选择器。

* {
   box-sizing: border-box;
}

3.2 -> 内边距

padding设置内容和边框之间的距离。

基础写法

默认内容是顶着边框来放置的。用padding来控制这个距离。

可以给四个方向都加上边距

  • padding-top。
  • padding-bottom。
  • padding-left。
  • padding-right。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    
    <div>
        路飞太郎
    </div>
 
</body>
</html>

style.css

div {
    height: 200px;
    width: 300px;
}

展示结果:

加上padding之后:

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    
    <div>
        路飞太郎
    </div>
 
</body>
</html>

style.css

div {
    height: 200px;
    width: 300px;
    padding-top: 5px;
    padding-left: 10px; 
}

展示结果:

此时可以看到带有了一个绿色的内边距。

注意:

  • 整个盒子的大小从原来的300 * 200 => 310 * 205。说明内边距也会影响到盒子大小(撑大盒子)。
  • 使用box-sizing: border-box属性也可以使内边距不再撑大盒子。(和上面border类似)。

3.2.1 -> 复合写法

可以把多个方向的padding合并到一起。


padding: 5px;表示四个方向都是 5px

padding: 5px 10px;表示上下内边距 5px,左右内边距为 10px

padding: 5px 10px 20px;表示上边距 5px,左右内边距为 10px,下内边距为 20px

padding: 5px 10px 20px 30px;表示 上5px,右10px,下20px,左30px (顺时针)


控制台中选中元素,查看右下角,是很清楚的。

3.3 -> 外边距

基础写法

控制盒子和盒子之间的距离。

可以给四个方向都加上边距:

  • margin-top。
  • margin-bottom。
  • margin-left。
  • margin-right。


test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    
    <div class="first">路飞太郎</div>
    <div>索隆十郎</div>
 
</body>
</html>

style.css

div {
    background-color: skyblue;
    width: 200px;
    height: 200px;
}
.first {
    margin-bottom: 20px;
}

展示结果:

3.3.1 -> 复合写法

规则同padding。


margin: 10px;四个方向都设置

margin: 10px 20px;上下为 10,左右 20

margin: 10px 20px 30px;上 10,左右 20,下 30

margin: 10px 20px 30px 40px;上 10,右 20,下 30,左 40

3.4 -> 块级元素水平居中

前提:

  • 指定宽度(如果不指定宽度,默认和父元素一致)。
  • 把水平margin设为auto。

三种写法均可。


margin-left: auto; margin-right: auto;

margin: auto;

margin: 0 auto;


示例:

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    
    <div>路飞太郎</div>
 
</body>
</html>

style.css

div {
    width: 500px;
    height: 200px;
    background-color: skyblue;
    margin: 0 auto;
}

展示结果:

注意:

  • 这个水平居中的方式和text-align不一样。
  • margin: auto是给块级元素用得到。
  • text-align: center是让行内元素或者行内块元素居中的。

另外,对于垂直居中,不能使用"上下margin为auto" 的方式。

4 -> 去除浏览器默认样式

浏览器会给元素加上一些默认的样式,尤其是内外边距。不同浏览器的默认样式存在差别。为了保证代码在不同的浏览器上都能按照统一的样式显示,往往我们会去除浏览器默认样式。

使用通配符选择器即可完成这件事情。

* {

    marign: 0;

    padding: 0;

}

5 -> 弹性布局

创建一个div,内部包含三个span。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
    }
    div>span {
        background-color: rgb(24, 220, 24);
        width: 100px;
    }
    </style>
 
</head>
 
<body>
    
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
       
</body>
</html>

展示结果:

当我们给div加上display: flex;之后:

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
    }
    div>span {
        background-color: rgb(24, 220, 24);
        width: 100px;
    }
    </style>
 
</head>
 
<body>
    
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
       
</body>
</html>

展示结果:

此时看到,span有了高度,不再是 "行内元素了"。

再给div加上justify-content: space-around;

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        justify-content: space-around;
    }
    div>span {
        background-color: rgb(24, 220, 24);
        width: 100px;
    }
    </style>
 
</head>
 
<body>
    
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
       
</body>
</html>

展示结果:

此时可以看到这些span已经能够水平隔开了。

把justify-content: space-around; 改为 justify-content: flex-end; 可以看到此时三个元素在右侧显示了。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        /* justify-content: space-around; */
        justify-content: flex-end;
    }
    div>span {
        background-color: rgb(24, 220, 24);
        width: 100px;
    }
    </style>
 
</head>
 
<body>
    
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
       
</body>
</html>

展示结果:

6 -> flex布局基本概念

flex是flexible box的缩写。意思为"弹性盒子"。


任何一个html元素,都可以指定为display:flex完成弹性布局。


flex布局的本质是给父盒子添加display:flex属性,来控制子盒子的位置和排列方式。


基本概念:


被设置为display:flex属性的元素,称为flex container。

它的所有子元素立刻称为了该容器的成员,称为flex item。

flex item可以纵向排列,也可以横向排列,称为flex direction(主轴)。


注意:

当父元素设置为display: flex之后,子元素的float、clear、vertical-align都会失效。

6.1 -> 常用属性

6.1.1 -> justify-content

设置主轴上的子元素排列方式。

使用之前一定要确定好主轴是哪个方向。

属性取值

image.png

未指定justify-content时,默认按照从左到右的方向布局。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
    }
    div span {
        width: 100px;
        height: 100px;
        background-color: rgb(24, 220, 24);
    }
    </style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
        <span>乔巴卫门</span>
        <span>海侠甚平</span>
    </div>
 
</body>
</html>

展示结果:

设置justify-content: flex-end,此时元素都排列到右侧了。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        justify-content: flex-end;
    }
    div span {
        width: 100px;
        height: 100px;
        background-color: rgb(24, 220, 24);
    }
    </style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
        <span>乔巴卫门</span>
        <span>海侠甚平</span>
    </div>
 
</body>
</html>

展示结果:

设置jutify-content: center,此时元素居中排列。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        /* justify-content: flex-end; */
        justify-content: center;
    }
    div span {
        width: 100px;
        height: 100px;
        background-color: rgb(24, 220, 24);
    }
    </style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
        <span>乔巴卫门</span>
        <span>海侠甚平</span>
    </div>
 
</body>
</html>

展示结果:

设置justify-content: space-around;平分了剩余空间。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        /* justify-content: flex-end; */
        /* justify-content: center; */
        justify-content: space-around;
    }
    div span {
        width: 100px;
        height: 100px;
        background-color: rgb(24, 220, 24);
    }
    </style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
        <span>乔巴卫门</span>
        <span>海侠甚平</span>
    </div>
 
</body>
</html>

展示结果:

设置justify-content: space-between;先两边元素贴近边缘,再平分剩余空间。

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 100%;
        height: 150px;
        background-color: skyblue;
        display: flex;
        /* justify-content: flex-end; */
        /* justify-content: center; */
        /* justify-content: space-around; */
        justify-content: space-between;
    }
    div span {
        width: 100px;
        height: 100px;
        background-color: rgb(24, 220, 24);
    }
    </style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
        <span>乔巴卫门</span>
        <span>海侠甚平</span>
    </div>
 
</body>
</html>

展示结果:

6.1.2 -> align-items

设置侧轴上的元素排列方式。

在上面的代码中,我们是让元素按照主轴的方向排列,同理我们也可以指定元素按照侧轴方向排列。

image.png

取值和justify-content差不多。

理解stretch(拉伸):

这个是align-content的默认值。意思是如果子元素没有被显式指定高度,那么就会填充满父元素的高度。


test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 500px;
        height: 500px;
        background-color: rgb(24, 220, 24);
        display: flex;
        justify-content: space-around;
    }
    div span {
        width: 150px;
        background-color: skyblue;
    }
</style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
 
</body>
</html>

展示结果:

可以使用align-items实现垂直居中。


test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    div {
        width: 500px;
        height: 500px;
        background-color: rgb(24, 220, 24);
        display: flex;
        justify-content: space-around;
        align-items: center;
    }
    div span {
        width: 150px;
        height: 100px;
        background-color: skyblue;
    }
</style>
 
</head>
 
<body>
 
    <div>
        <span>路飞太郎</span>
        <span>索隆十郎</span>
        <span>山五郎</span>
    </div>
 
</body>
</html>

展示结果:

注意:

align-items只能针对单行元素来实现。如果有多行元素,就需要使用item-contents。

目录
相关文章
|
2月前
|
前端开发 JavaScript 测试技术
前端测试技术中,如何提高集成测试的效率?
前端测试技术中,如何提高集成测试的效率?
|
2天前
|
前端开发 JavaScript 开发者
前端 CSS 优化:提升页面美学与性能
前端CSS优化旨在提升页面美学与性能。通过简化选择器(如避免复杂后代选择器、减少通用选择器使用)、合并样式表、合理组织媒体查询,可减少浏览器计算成本和HTTP请求。利用硬件加速和优化动画帧率,确保动画流畅。定期清理冗余代码并使用缩写属性,进一步精简代码。这些策略不仅加快页面加载和渲染速度,还提升了视觉效果,为用户带来更优质的浏览体验。
|
2月前
|
前端开发 JavaScript API
惊呆了!这些前端技术竟然能让你的网站实现无缝滚动效果!
【10月更文挑战第30天】本文介绍了几种实现网页无缝滚动的技术,包括CSS3的`scroll-snap`属性、JavaScript的Intersection Observer API以及现代前端框架如React和Vue的动画库。通过示例代码展示了如何使用这些技术,帮助开发者轻松实现流畅的滚动效果,提升用户体验。
221 29
|
2月前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
49 6
|
2月前
|
前端开发 数据处理 Android开发
Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍
本文深入探讨了Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍,以及具体操作步骤、常见问题解决、高级调试技巧、团队协作中的调试应用和未来发展趋势,旨在帮助开发者提高调试效率,提升应用质量。
60 8
|
2月前
|
前端开发 JavaScript 搜索推荐
前端懒加载:提升页面性能的关键技术
前端懒加载是一种优化网页加载速度的技术,通过延迟加载非首屏内容,减少初始加载时间,提高用户访问体验和页面性能。
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
61 5
|
2月前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
75 5
|
2月前
|
移动开发 前端开发 JavaScript
惊!这些前端技术竟然能让你的网站在移动端大放异彩!
随着互联网技术的发展,移动设备成为主要的上网工具。本文介绍了几种关键的前端技术,包括响应式设计、图片优化、字体选择、HTML5和CSS3的应用、性能优化及手势操作设计,帮助开发者提升网站在移动端的显示效果和用户体验。示例代码展示了如何实现简单的双向绑定功能。
44 3
|
2月前
|
数据采集 前端开发 安全
前端测试技术
前端测试是确保前端应用程序质量和性能的重要环节,涵盖了多种技术和方法