响应式开发(黑马教程笔记)-Bootsrap

一,响应式开发原理

实际上是通过媒体查询,针对不同的宽度的设备进行布局和样式的设置。从而达到 适配不同设备的目的。
在这里插入图片描述
需要一个父级作为布局容器,来配合子级元素来实现变化效果。
原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,再改变里面子元素的排布方式和大小,从而实现在不同屏幕下,看到的不同的页面布局和样式变化。
在这里插入图片描述

<!doctype html>
<html>

	<head>
		<meta charset="utf-8">
		<title></title>
		<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
		<style type="text/css">
			.container{
				height: 150px;
				background-color: pink;
				margin: 0 auto;
				
			}
			/* 一,超小屏幕下 ,768px下 */
			@media  screen and (max-width:767px){
				.container{
					width:100%;
				}
				
			}
			/* 二,小屏幕下,大于768 */
			@media  screen and (min-width:768px){
				
				.container{
					width:750px;
					}
			}
			/* s三,中屏幕下,大于992 */
			@media  screen and (min-width:992px){
				.container{
				width:970px;
				}
			}
			/* 四,大屏幕下,大于1200 */
			@media  screen and (min-width:1200px){
				.container{
				width:1170px;
				}
			}
			
		</style>
	</head>

	<body>
		<!-- 响应式开发里面,首先需要一个布局容器 -->
		<div class="container"></div>
	</body>

</html>

二,导航栏的响应式布局实例

<!doctype html>
<html>

	<head>
		<meta charset="utf-8">
		<title></title>
		<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
		<style type="text/css">
			*{
				margin: 0;
				padding: 0;
			}
			.container{
				background-color: pink;
				width: 750px;
				margin: 0 auto;
				
			}
			.container ul{
				list-style: none;
			}
			.container ul li{
				float: left;
				width: 93.75px;
				height: 30px;
				background: red;
				
			}
			
			/* 一,超小屏幕下 ,768px下 */
			@media  screen and (max-width:767px){
				.container{
					width:100%;
				}
				.container ul li{
					width: 25%;
				}
				/* 也就是正常情况下,按照上面的样式去显示.
				一旦小于767px,则显示这里的样式, */
			}
			
		</style>
	</head>

	<body>
		<!-- 响应式开发里面,首先需要一个布局容器 -->
		<div class="container">
			<ul>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
				<li>导航栏</li>
			</ul>
		</div>
	</body>

</html>

实现的效果:
在这里插入图片描述

三,快速开发-Bootstrap

前端开发框架,一些常用结构已经搭建好了,复制过来就可以用
在这里插入图片描述

四,Bootstrap基本模板

<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" rel="stylesheet">

    <!-- HTML5 shim 和 Respond.js 是为了让 IE8 支持 HTML5 元素和媒体查询(media queries)功能 -->
    <!-- 警告:通过 file:// 协议(就是直接将 html 页面拖拽到浏览器中)访问页面时 Respond.js 不起作用 -->
    <!--[if lt IE 9]>
      <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
      <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
    <![endif]-->
  </head>
  <body>
    <h1>你好,世界!</h1>

    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
    <script src="https://cdn.jsdelivr.net/npm/jquery@1.12.4/dist/jquery.min.js"></script>
    <!-- 加载 Bootstrap 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js"></script>
  </body>
</html>

在这里插入图片描述
它的样式主要设置在对应名字的class里面,而我们想修改它的样式,就再命名一个类名,利用层叠样式表权重大的覆盖权重低的样式就可以了,也就是说,基本样式利用bootstrap来设置,然后想修改成啥样自己定义。就免去了程序员设置基础样式的大量工作,缺点也有,就是你修改覆盖后,bootstrap里面其实会存在很多被覆盖的无效的样式代码。

五,Bootstrap的布局容器

Bootstrap需要为页面内容和栅格系统包裹一个.container容器,Boostrap预先定义好了这个类,就叫做**.container**
在这里插入图片描述
也就是说,当我们引入Bootstrap之后,定义好.container之后,它就已经帮我们把媒体查询的多个挡位都写好了 !宽度都订好了,只要直接用就行。
在这里插入图片描述
并且,初始化的css样式它也给我们写好了!!
例如,只写这一句话时:

<div class="container" style="background-color: pink;">123</div>

就已经划分好挡位,做好媒体查询了:
在这里插入图片描述
在这里插入图片描述
另一个预定义好的类,则是始终100%的,并没有划分挡位,适合做移动端开发。
对比一下:
在这里插入图片描述
也就是说,做响应式,主要是应用.conntainer这个类。

六,Bootstrap栅格系统

把容器划分为12等份,当屏幕尺寸变化时,对应的布局容器发生变化,于是划分的12等分亦随之变化。
在这里插入图片描述

在这里插入图片描述
例如,对于宽屏幕的情况:

<!DOCTYPE html>
<html lang="zh-CN">
    <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>Bootstrap删减过的</title>
        <link href='https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css' rel="stylesheet">
		<style type="text/css">
			[class^="col-lg"]{
				border: 1px solid #ccc;
				background: pink;
			}
		</style>
	</head>
    <body>
		<div class="container">
			<div class="row">
				<div class="col-lg-3">1</div>
				<div class="col-lg-3">2</div>
				<div class="col-lg-3">3</div>
				<div class="col-lg-3">4</div>
			</div>
			<!-- 列数相加不超过12时会留有空白 -->
			<div class="row">
				<div class="col-lg-6">1</div>
				<div class="col-lg-2">2</div>
				<div class="col-lg-2">3</div>
			</div>
			<!-- 列数相加超过12会换行 -->
			<div class="row">
				<div class="col-lg-6">1</div>
				<div class="col-lg-5">2</div>
				<div class="col-lg-3">3</div>
			</div>
		</div>
    </body>
</html>


在这里插入图片描述

六,栅格系统的使用

像上面的写法,当屏幕变成1200px以下时,就会变成每个格子占一行。这也是bootstrap里面写好的媒体查询。

在这里插入图片描述
而当我们想随着宽度减少,每行的列数逐次减少时,就需要换一种写法了。
在这里插入图片描述
在这里插入图片描述

<div class="container">
			<div class="row" style="background-color: pink;">
				<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">1</div>
				<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">2</div>
				<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">3</div>
				<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">4</div>
				<!-- 大屏幕时,占3个格子
				较大屏幕,占4个格子
				小屏幕时,占6个格子
				超小屏幕,占12个格子 -->
			</div>
		</div>

在这里插入图片描述

七,栅格系统的列嵌套

Bootstrap栅格系统可以进行列嵌套。也就是说,其中的一个栅格,又可以划分为12个栅格。当然,再划分之前,需要添加一次class=row。把那个padding取消掉!且高度自动和父元素一致。

<div class="container">
			<div class="row" >
				<div class="col-lg-4">
					<div class="row">
						<div class="col-lg-2" style="background: green;">2</div>
						<div class="col-lg-2" style="background: green;">2</div>
						<div class="col-lg-2" style="background: green;">2</div>
						<div class="col-lg-4" style="background: green;">3</div>
						<div class="col-lg-2" style="background: green;">2</div>
					</div>
				</div>
					
				<div class="col-lg-4 ">4</div>
				<div class="col-lg-4 ">4</div>
			</div>
		</div>

在这里插入图片描述

八,栅格系统的列偏移

在这里插入图片描述

		<div class="container">
			<div class="row" >
				<div class="col-lg-3">左侧</div>
				<div class="col-lg-3 col-md-offset-6">右侧</div>
			</div>
		</div>

在这里插入图片描述
同理,如果只有一份,还想要偏移到中间的话:

<div class="container">
			<div class="row" >
				<div class="col-lg-6 col-md-offset-3">右侧</div>
			</div>
		</div>

九,栅格系统的列排序

在这里插入图片描述

<div class="container">
			<div class="row" >
				<div class="col-lg-3 col-md-push-9">左侧</div>
				<div class="col-lg-3 col-md-offset-6 col-md-pull-9">右侧</div>
			</div>
		</div>

对于右侧的盒子,先平移到最右侧,然后再列排序拉过来。
在这里插入图片描述

十,栅格系统的响应式工具

当屏幕尺寸缩小时,有时候我们需要的不是换行,而是直接不显示某些元素。这时候就需要用到bootstrap的显示隐藏功能。
在这里插入图片描述
例如:我只在中屏幕下隐藏某列:

<div class="container">
			<div class="row" >
				<div class="col-xs-3">1</div>
				<div class="col-xs-3">2</div>
				<div class="col-xs-3 hidden-md">3</div>
				<div class="col-xs-3">4</div>
			</div>
		</div>

在这里插入图片描述

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值