web前端学习(二)html学习笔记部分(9)-- 响应式布局
1.2.23 响应式布局基础
1.2.23.1 响应式布局介绍
1.响应式布局是2010年5月份提出的一个概念,简而言之,就是一个网站能够兼容多终端 -- 而不是为每个终端做一个特定的版本。这个概念是为解决移动互联网浏览而诞生的,其目的是为用户提供更加舒适的界面和更好的用户体验。
2.优缺点
优点:1)面对不同分辨率设备灵活性强
2)能够快捷解决多设备显示适应问题
缺点:1)兼容各种设备工作量大,效率低下
2)代码累赘,会出现隐藏无用的元素,加载时间长
例子:www.etao.com(现在在电脑网页端打开好像没有用响应式布局了)
1.2.23.2 响应式布局效果
1.CSS中的Media Query(媒介查询):
设备宽高:device-width,device-height
渲染窗口的宽和高:width,height
设备的手持方向:orientation
设备的分辨率:resolution
2.使用方法:
外联
内嵌样式
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="style.css" type="text/css" media="only screen and (max-width:640px)">
<!--外联样式-->
<style>
<!--内嵌样式-->
<!--注意and之后和括号之间的空格不能省略-->
@media screen and (min-width:640px){
body{
background-color: blueviolet;
}
}
</style>
</head>
<body>
</body>
</html>
1.2.23.3 响应式布局操作
传统的js操作实现响应式布局
index.html
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width = device-width,initial-scale=1">
<!--initial-scale=1的作用是指按原比例缩放-->
<title>Title</title>
<link rel="stylesheet" href="style.css" type="text/css">
</head>
<body>
<div class="heading"></div>
<div class="container">
<div class="left"></div>
<div class="main"></div>
<div class="right"></div>
</div>
<div class="footing"></div>
</body>
</html>
style.css
*{
margin:0px;
padding:0px;
}
.heading,
.container,
.footing{
margin: 10px auto;
}
.heading{
height:100px;
background-color: chocolate;
}
.left,
.right,
.main{
background-color: cornflowerblue;
}
.footing{
height:100px;
background-color: aquamarine;
}
@media screen and (min-width: 960px){
.heading,
.container,
.footing{
width:960px;
}
.left,
.main,
.right{
float:left;
height:500px;
}
.left,
.right{
width:200px;
}
.main{
margin-left:5px;
margin-right: 5px;
width:550px;
}
.container{
height:500px;
}
}
@media screen and (min-width:600px) and (max-width:960px){
.heading,
.container,
.footing{
width:600px;
}
.left,
.main{
float:left;
height:400px;
}
.right{
display:none;
}
.left{
width:160px;
}
.main{
margin-left:5px;
width:435px;
}
.container{
height:400px;
}
}
@media screen and (max-width:600px){
.heading,
.container,
.footing{
width:400px;
}
.left,
.right{
width:400px;
height:100px;
}
.main{
margin-top:10px;
width:400px;
height:200px;
}
.right{
margin-top:10px;
}
.container{
height:420px;
}
}
1.2.24 响应式布局之bootstrap
1.2.24.1 Bootstrap介绍
1.了解Bootstrap
简洁、直观、强悍的前端开发框架、让web开发更迅速、简单。
2.优点:
快速、简单、灵活的栅格系统、小而强大、响应式布局、跨平台等
bootstrap在线引入
<!DOCTYPE html>
<html>
<head>
<title>Bootstrap 实例</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1"> <!--BootStrap中文网提供的免费CDN加速服务--> <!--Bootstrap核心CSS文件-->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/4.1.3/css/bootstrap.min.css"> <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
<script src="http://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <!--Bootstrap核心JavaScript文件-->
<script src="http://cdn.bootcss.com/bootstrap/4.1.3/js/bootstrap.min.js"></script> </head> <body>
</body>
</html>
1.2.24.2 css、组件以及JS介绍
usingbootstrap.html
<!DOCTYPE html>
<html>
<head>
<title>Bootstrap 实例</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1"> <!--BootStrap中文网提供的免费CDN加速服务--> <!--Bootstrap核心CSS文件-->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.2.0/css/bootstrap.min.css"> <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->
<script src="http://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <!--Bootstrap核心JavaScript文件-->
<script src="http://cdn.bootcss.com/bootstrap/3.2.0/js/bootstrap.min.js"></script> <link rel="stylesheet" href="ownstyle.css" type="text/css"> </head> <body>
<div class="container">
<div class="row">
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
<div class="col-md-1">.col-md-1</div>
</div>
<div class="row">
<div class="col-md-8">.col-md-8</div>
<div class="col-md-4">.col-md-4</div>
</div>
<div class="row">
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
</div>
<div class="row">
<div class="col-md-6">.col-md-6</div>
<div class="col-md-6">.col-md-6</div>
</div>
</div>
</body>
</html>
ownstyle.css
.row{
margin-bottom: 20px;
}
.row .row{
margin-top: 0px;
margin-bottom: 10px;
}
[class*="col-"]{
padding-top: 15px;
padding-bottom: 15px;
background-color: #eee;
background-color: rgba(86,61,124,.15);
/*后面的.15是指透明度和0.15一个效果*/
/*这里本来老师讲写的两行内容,但是只有后一个有作用,冲突了才会这样处理*/
border:1px solid #dddddd;
border:1px solid rgba(86,61,124,.2);
}
老师用的是老版的所以直接在head中修改bootstrap的版本号就可以了。
1.2.24.3 响应式布局之使用Bootstrap
这里我发现了几个问题:
margin设定了之后是指距离元素的border距离,与其他元素的margin无关
bootstrap里有很多已经设定好的类名,我们可以在网站中检查元素来知道到底该用什么类。
一般用container来放置居中元素。
web前端学习(二)html学习笔记部分(9)-- 响应式布局的更多相关文章
- CSS3学习笔记--media query 响应式布局
语法:@media screen and (min-width: 320px) and (max-width : 479px) media属性后面跟着的是一个 screen 的媒体类型(上面说过的十种 ...
- Web前端与移动开发学习路线图
文章转载自「开发者圆桌」一个关于开发者入门.进阶.踩坑的微信公众号 这里整理的Web前端与移动开发学习路线图包含初中级两个部分,你可以通过百度云盘下载观看对应的视频 链接: http://pan.ba ...
- 想做web前端project师应该学习些什么?
偶然间看到这篇文章.感觉博主写的挺不错的,假设你想做web前端project师的话,建议您阅读下面这篇文章,事实上web前端project师所做的工作事实上就是站点设计,有些小公司的美工事实上就是做w ...
- 最全的WEB前端开发程序员学习清单
史上最全的WEB前端开发程序员学习清单! 今天为什么要给大家分享这篇文章呢,我发现最近来学前端的特别多,群里面整天都有人问:前端好找工作吗?前端要怎么学啊?前端工资怎么样?前端XX,前端XXX,虽然我 ...
- CSS3与页面布局学习笔记(四)——页面布局大全(负边距、双飞翼、多栏、弹性、流式、瀑布流、响应式布局)
一.负边距与浮动布局 1.1.负边距 所谓的负边距就是margin取负值的情况,如margin:-100px,margin:-100%.当一个元素与另一个元素margin取负值时将拉近距离.常见的功能 ...
- 【学习笔记】响应式布局的常用解决方案(媒体查询、百分比、rem、和vw/vh)
原文转载:https://blog.csdn.net/sinat_17775997/article/details/81020417 一.媒体查询 不同物理分辨率的设备,在还原设计稿时,css中设置的 ...
- CSS学习笔记——响应式布局
响应式布局 响应式布局是现在很流行的一个设计理念,随着移动互联网的盛行,为解决如今各式各样的浏览器分辨率以及不同移动设备的显示效果,设计师提出了响应式布局的设计方案.所谓的响应式布局,就是一个网站能够 ...
- [学习笔记]viewport定义,弹性布局,响应式布局
一,移动端宽度设置viewport视图窗口,<meta name="viewport" content="width=device-width,initial-sc ...
- CSS响应式布局学习笔记(多种方法解决响应式问题)
在做web开发的工作中,会遇到需要我给页面根据设计的要求,进行响应式布局,这里跟大家分享下我对于响应式布局的解决方法: 我主要利用的是CSS3 媒体查询,即media queries,可以针对不同的媒 ...
随机推荐
- springmvc 文件下载分批读取,防止内存溢出
参考 https://blog.csdn.net/u014732956/article/details/51404086
- java笔试之取近似值
写出一个程序,接受一个正浮点数值,输出该数值的近似整数值.如果小数点后数值大于等于5,向上取整:小于5,则向下取整. package test; import java.util.*; import ...
- _itoa _itow _itot atoi atof atol
函数原型: char *_itoa( int value, char *string, int radix ); //ANSI wchar_t * _itow( int value, wchar_t ...
- light oj 1037 状压dp
#include <iostream> #include <cstdlib> #include <cstring> #include <queue> # ...
- https://github.com/ronggang/transmission-web-control
首先需要保证你的电脑可以链接国际互联网 如果只能链接大型局域网,那么请您带着电脑出国以便于可以顺利安装https://github.com/ronggang/transmission-web-cont ...
- Python基础-列表、元组、字典、字符串(精简解析),全网最齐全。
一.列表 =====================================================1.列表的定义及格式: 列表是个有序的,可修改的,元素用逗号隔开,用中括号包围的序列 ...
- [转]C#改变无边框窗体大小
#region 改变窗体大小 const int WM_NCHITTEST = 0x0084; ; //左边界 ; //右边界 ; //上边界 ; //左上角 ; //右上角 ; //下边界 cons ...
- 通过pyppeteer来爬取今日头条
import asyncio from pyppeteer import launch async def main(): browser = await launch() page = await ...
- 冒泡排序算法[C++]
冒泡排序应该是最容易实现的一种排序算法了.其基本思想是:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后.然后比较第2个数和第3个数,将小 ...
- Leetcode401Binary Watch二进制手表
二进制手表顶部有 4 个 LED 代表小时(0-11),底部的 6 个 LED 代表分钟(0-59). 每个 LED 代表一个 0 或 1,最低位在右侧. 给定一个非负整数 n 代表当前 LED 亮着 ...