【HTML5】弹性盒子实现导航栏和留言框

调CSS就像上方那样,代码逐渐变得扭曲,情绪逐渐变得暴躁。


 目录

弹性盒子的核心属性

1、display设置元素生成框

2、弹性盒子比例划分

2.1flex-basis基本宽度

2.2flex-grow放大宽度

2.3flex-shrink缩小宽度

2.4单独的一个flex用法

3、flex-direction属性

3.1row排列

3.2row-reverse排列

3.3column排列

3.4column-reverse排列

4、flex的两种对齐方式

5、列表

5.1列表的用法

5.2列表超链接的用法

6、弹性盒子实现导航栏

6.1html源码 

7、表单实现留言框

7.1html源码 

7.2css源码 


前言:

大家好,我是拳击哥。在我们日常生活中,我们点击一个网页PC端显示的是一个状态用手机看是另外一种状态,这时候需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式。那么这时候我们可以用到弹性盒子。下面我就来讲解弹性盒子的各个属性用法。


我任意打开一个网站,PC端显示时,我拖动检查框发现整个页面只能显示一半。那如果不进行弹性设置,当PC端的尺寸应用到手机上的时候,手机上显示的也是页面的一半

当我切换切换设备为手机端后,我把检查框往左拖动发现页面随着尺寸自适应生成了适合屏幕的大小,这就是弹性盒子的用法。

以上页面只是随机查找的,里面的功能不一定是使用弹性盒子。但我想告诉大家的是弹性盒子能使一个网页在PC端显示一种状态,在手机端显示根据PC端自适应生成适合手机端的状态。我们可以这样理解大屏显示是什么样子,小屏显示是什么样子。这样就不难理解了。


弹性盒子的核心属性

外层容器里面有三个弹性项:

  • 由弹性容器(Flex container)和弹性子元素(Flex item)组成
  • 通过设置 display 属性的值为 flex 或 inline-flex将其定义为弹性容器
  • 包含了一个或多个弹性子元素

1、display设置元素生成框

我们需要将显示函数display设置成flex,display属性是规定元素生成框是什么样的类型的,比如我要设置成flex弹性盒子我可以这样做:display:flex

如以下程序:

    <style>
		.test 
		{
			display: flex;
		}
    </style>
	<div class="test">测试</div>

2、弹性盒子比例划分

  • flex-grow 放大
  • flex-shrink 缩小
  • flex-basis 自然宽度
  • flex-wrap 换行

今天我们讲常用的三个属性:flex-grow 放大、flex-shrink 缩小、flex-basis 自然宽度。


2.1flex-basis基本宽度

我设置父类宽度为400px,四个“孩子”的基本宽度分别为10px、50px、100px、120px。这些px是什么呢?就是四个“孩子”各自盒子占的宽度。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>测试</title>
	</head>
	<style>
		.box {
			width: 400px;
			height: 50px;
			display: flex;
			flex-direction:row;	
			flex-grow: ;
			background-color: whitesmoke;
		}
		.test {
			height: 50px;
		}
		.test:nth-child(1) {
            width: 10px;
			background: red;
		}
		.test:nth-child(2) {
			width: 50px;
			flex-basis: auto;
			background: skyblue;
		}
		.test:nth-child(3) {
			width: 100px;
			flex-basis: auto;
			background: green;
		}
		.test:nth-child(4) {
			width: 120px;
			flex-basis: auto;
			background: palegreen;
		}
	</style>
	<div class="box">
	<div class="test">1</div>
	<div class="test">2</div>
	<div class="test">3</div>
	<div class="test">4</div>
	</div>
	</body>
</html>

 显示效果

我们可以看到1、2、3、4区域后面有一块多余的灰色区域。那么我在第2个child里加上flex-grow:2会发生什么呢


2.2flex-grow放大宽度

在2.1代码上修改,将flex-grow:2

评论 36
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只爱打拳的程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值