前端笔记-day06

2024-05-14 12:52
文章标签 笔记 前端 frontend day06

本文主要是介绍前端笔记-day06,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 01-浮动-基本使用
    • 02-浮动-产品布局
    • 03-浮动-清除浮动带来的影响
    • 04-清除浮动-额外标签法
    • 05-清除浮动-单伪元素法
    • 06-清除浮动-双伪元素法
      • 单伪元素和双伪元素CSS
    • 07-清除浮动-overflow
    • 08-flex布局-体验
    • 09-flex布局-组成
    • 10-flex布局-主轴对齐方式
    • 11-flex布局-侧轴对齐方式
    • 13-flex布局-修改主轴方向
    • 14-flex布局-弹性伸缩比
    • 15-flex布局-弹性换行
    • 16-flex布局-行对齐方式
    • 17-综合案例-抖音解决方案

01-浮动-基本使用

<!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>/* 特点:顶对齐,具备行内块显示模式特点 *//* 浮动的盒子会脱离标准流的控制,不再占用原来的位置 */.one{width: 100px;height: 100px;background-color: red;float: left;}.two{width: 200px;height: 200px;background-color: orange;/* float: left; *//* float: right; */}</style>
</head>
<body><div class="one"></div><div class="two"></div>
</body>
</html>

在这里插入图片描述

02-浮动-产品布局

Document
<div class="product"><div class="left"></div><div class="right"><ul><li></li><li></li><li></li><li></li><li></li><li></li><li></li><li></li></ul></div>
</div>

在这里插入图片描述

03-浮动-清除浮动带来的影响

<!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>.top{margin: 10px auto;width: 1200px;/* height: 300px; */background-color: pink;}.left{float: left;width: 200px;height: 300px;background-color: skyblue;}.right{float: right;width: 950px;height: 300px;background-color: orange;}.button{height: 100px;background-color: red;}</style>
</head>
<body><div class="top"><div class="left"></div><div class="right"></div></div><div class="button"></div>
</body>
</html>

在这里插入图片描述

04-清除浮动-额外标签法

<!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>.top{margin: 10px auto;width: 1200px;/* height: 300px; */background-color: pink;}.left{float: left;width: 200px;height: 300px;background-color: skyblue;}.right{float: right;width: 950px;height: 300px;background-color: orange;}.button{height: 100px;background-color: red;}/* 方法一:额外标签法:在父元素内容的最后添加一个块级元素,设置CSS属性clear:both */.clearfix{clear: both;}</style>
</head>
<body><div class="top"><div class="left"></div><div class="right"></div><div class="clearfix"></div></div><div class="button"></div>
</body>
</html>

在这里插入图片描述

05-清除浮动-单伪元素法

<!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>.top{margin: 10px auto;width: 1200px;/* height: 300px; */background-color: pink;}.left{float: left;width: 200px;height: 300px;background-color: skyblue;}.right{float: right;width: 950px;height: 300px;background-color: orange;}.button{height: 100px;background-color: red;}/* 单伪元素法 *//* 伪元素要想生效必须配合content使用 */.clearfix::after{content: "";display: block;clear: both;}</style>
</head>
<body><!-- 要使用clearfix只需要在 --><div class="top clearfix"><div class="left"></div><div class="right"></div></div><div class="button"></div>
</body>
</html>

在这里插入图片描述

06-清除浮动-双伪元素法

<!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>.top{margin: 10px auto;width: 1200px;/* height: 300px; */background-color: pink;}.left{float: left;width: 200px;height: 300px;background-color: skyblue;}.right{float: right;width: 950px;height: 300px;background-color: orange;}.button{height: 100px;background-color: red;}/* 双伪元素法 */.clearfix::before,.clearfix::after{content: "";display: table;}.clearfix::after{clear: both;}</style>
</head>
<body><div class="top clearfix"><div class="left"></div><div class="right"></div></div><div class="button"></div>
</body>
</html>

在这里插入图片描述

单伪元素和双伪元素CSS

/* 单伪元素法 */
/* 伪元素要想生效必须配合content使用 */
.clearfix::after{content: "";display: block;clear: both;
}/* 双伪元素法 */
.clearfix::before,
.clearfix::after{content: "";display: table;
}
.clearfix::after{clear: both;
}

07-清除浮动-overflow

<!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>.top{margin: 10px auto;width: 1200px;/* height: 300px; */background-color: pink;/* 方法四:清除浮动:父元素添加CSS属性overflow:hidden */overflow: hidden;}.left{float: left;width: 200px;height: 300px;background-color: skyblue;}.right{float: right;width: 950px;height: 300px;background-color: orange;}.button{height: 100px;background-color: red;}</style>
</head>
<body><div class="top"><div class="left"></div><div class="right"></div></div><div class="button"></div>
</body>
</html>

在这里插入图片描述

08-flex布局-体验

<!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>.box{display: flex;justify-content: space-between;/* height: 300px; */border: 1px solid #000;}.box div{/* float: left; *//* margin: 50px; */width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><div class="box"><div></div><div></div><div></div></div>
</body>
</html>

在这里插入图片描述

09-flex布局-组成

<!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>/* box是弹性容器 */.box{display: flex;height: 300px;border: 1px solid #000;}/* box 里面的div是弹性盒子:沿着主轴方向排列 */.box div{width: 200px;/* 拉伸:跟父级一样 *//* height: 100px; */background-color: pink;}/* 主轴:默认水平方向 *//* 侧轴:垂直方向 */</style>
</head>
<body><div class="box"><!-- 压缩:父级宽度不够了 --><div>1</div><div>2</div><div>3</div><div>1</div><div>2</div><div>3</div></div>
</body>
</html>

在这里插入图片描述

10-flex布局-主轴对齐方式

<!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>.box{display: flex;/* 默认写不写没区别 *//* justify-content: flex-start; *//* 弹性盒子终点对齐 *//* justify-content: flex-end; *//* 居中 *//* justify-content: center; *//* 父级剩余部分分配成间距 *//* 弹性盒子之间的间距相等 */justify-content: space-between;/* 间距出现在弹性盒子两侧 *//* 视觉效果:弹性盒子之间的间距是两端间距的2*/justify-content: space-around;/* 各个间距都相等 */justify-content: space-evenly;height: 300px;border: 1px solid #000;}.box div{height: 100px;width: 200px;background-color: pink;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div></div>
</body>
</html>

在这里插入图片描述

11-flex布局-侧轴对齐方式

<!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>.box{display: flex;/* 弹性盒子在侧轴方向没有尺寸才能拉伸,也就是弹性盒子没有height属性 *//* align-items: stretch; *//* 弹性盒子排列方式 *//* align-items: center; *//* align-items: flex-start; *//* align-items: flex-end; */height: 300px;border: 1px solid #000;}/* 对弹性盒子进行设置 *//* 让第二个盒子侧轴居中对齐 */.box div:nth-child(2){align-self: center;}.box div{width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div></div>
</body>
</html>

在这里插入图片描述

13-flex布局-修改主轴方向

<!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>.box{display: flex;/* 修改主轴为垂直方向 */flex-direction: column;/* 主轴垂直居中 */justify-content: center;/* 侧轴居中,视觉效果:水平居中 */align-items: center;width: 150px;height: 120px;background-color: pink;}img{width: 32px;height: 32px;}</style>
</head>
<body><div class="box"><img src="./20.jpg" alt=""><span>媒体</span></div>
</body>
</html>

在这里插入图片描述

14-flex布局-弹性伸缩比

<!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>.box{display: flex;/* 修改主轴方向 */flex-direction: column;height: 300px;border: 1px solid #000;}.box div{/* height: 100px; */background-color: pink;}.box div:nth-child(1){width: 200px;}/* flex属性是设置弹性盒子(占父级剩余份数)尺寸 */.box div:nth-child(2){flex: 1;}.box div:nth-child(3){flex: 2;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div></div>
</body>
</html>

在这里插入图片描述

15-flex布局-弹性换行

<!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>.box{display: flex;/* wrap 换行的意思 */flex-wrap: wrap;/* nowrap是默认值 不换行的意思 *//* flex-wrap: nowrap; */justify-content: space-between;height: 300px;border: 1px solid #000;}.box div{width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div><div>4</div><div>5</div><div>6</div><div>7</div><div>8</div><div>9</div><div>10</div><div>11</div><div>12</div></div>
</body>
</html>

在这里插入图片描述

16-flex布局-行对齐方式

<!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>.box{display: flex;flex-wrap: wrap;justify-content: space-between;/* 对一行显示的弹性盒子没有效果 *//* 调整对齐方式 *//* align-content: flex-start; *//* align-content: flex-end; *//* align-content: space-between; *//* align-content: space-around; *//* align-content: space-evenly; */height: 400px;border: 1px solid #000;}.box div{width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><div class="box"><div>1</div><div>2</div><div>3</div><div>4</div><div>5</div><div>6</div><div>7</div><div>8</div></div>
</body>
</html>

在这里插入图片描述

17-综合案例-抖音解决方案

<!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嵌套了ul标签,这个ul标签包含了四个li标签四个li标签进行了换行,所以对ul标签设置了弹性换行由于div是完整嵌套ul标签的,所以对ul标签设置了四个方向的内边距由于li标签是靠四个角对齐的,所以对设置主轴对齐方式和行对齐方式*//* 清除默认样式 */*{margin: 0;padding: 0;box-sizing: border-box;}li{/* 去掉列表前面的小点点 */list-style: none;}.box li{display: flex;width: 500px;height: 88px;border: 1px solid #000;}/* 设置外面的大盒子 */.box{margin: 50px auto;width: 1200px;height: 418px;border: 1px solid #ddd;border-radius: 10px;}/* 设置ul标签 */.box ul{display: flex;flex-wrap: wrap;justify-content: space-between;align-content: space-between;padding: 90px 40px 90px 60px;height: 418px;}.box .pic img{height: 85px;width: 84px;}.box .pic {margin-right: 15px;}.box .text h4{line-height: 40px;font-size: 20px;font-weight: 400;color: #333;}.box .text p{font-size: 14px;color: #666;}</style>
</head>
<body><div class="box"><ul><li><div class="pic"><img src="./20.jpg" alt=""></div><div class="text"><h4>换句话说大比分击败</h4><p>sajhhbJbsjajjjjj内减</p></div></li><li><div class="pic"><img src="./20.jpg" alt=""></div><div class="text"><h4>换句话说大比分击败</h4><p>sajhhbJbsjajjjjj内减</p></div></li><li><div class="pic"><img src="./20.jpg" alt=""></div><div class="text"><h4>换句话说大比分击败</h4><p>sajhhbJbsjajjjjj内减</p></div></li><li><div class="pic"><img src="./20.jpg" alt=""></div><div class="text"><h4>换句话说大比分击败</h4><p>sajhhbJbsjajjjjj内减</p></div></li></ul></div>
</body>
</html>

在这里插入图片描述

这篇关于前端笔记-day06的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/988785

相关文章

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

CSS去除a标签的下划线的几种方法

《CSS去除a标签的下划线的几种方法》本文给大家分享在CSS中,去除a标签(超链接)的下划线的几种方法,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧... 在 css 中,去除a标签(超链接)的下划线主要有以下几种方法:使用text-decoration属性通用选择器设置:使用a标签选择器,将tex

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处