移动端概述

移动端基础

  • 移动端设备屏幕尺寸非常多,碎片化严重
  • Android 设备有多种分辨率:480x800, 480x854, 540x960, 720x1280, 1080x1920等

常见移动端屏幕尺寸

image-20231108080506305

移动端调试方法

  • Chrome DevTools(谷歌浏览器)的模拟手机调试
  • 搭建本地 web 服务器,手机和服务器一个局域网内,通过手机访问服务器
  • 使用外网服务器,直接IP 或 域名 访问

总结

  • 移动端浏览器我们主要对 webkit 内核进行兼容
  • 我们现在开发的移动端主要针对于手机端开发
  • 现在移动端碎片化比较严重,分辨率和屏幕尺寸大小不一
  • 学会用谷歌浏览器模拟手机界面以及调试

视口

视觉视口 visual viewport

  • 字面意思,它是用户正在看到的网站的区域。注意:是网站的区域
  • 我们可以通过缩放去操作视觉视口,但不会影响布局视口,布局视口仍保持原来的宽度
image-20231108081254693

理想视口 ideal viewport

  • 为了使网站在移动端有最理想的浏览和阅读宽度而设定
  • 理想视口,对设备来讲,是最理想的视口尺寸
  • 需要手动填写 meta 视口标签通知浏览器操作
  • meta 视口标签的主要目的:布局视口的宽度应该与理想视口的宽度一致,简单理解就是设备有多宽,我们布局的视口就多宽

总结:

  • 视口就是浏览器显示页面内容的屏幕区域
  • 视口分为布局视口、视觉视口和理想视口
  • 我们移动端布局想要的是理想视口就是手机屏幕有多宽,我们的布局视口就有多宽
  • 想要理想视口,我们需要给我们的移动端页面添加 meta 视口标签

meta视口标签

<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" >
属性 解释说明
width 宽度设置的是viewport宽度,可以设置device-width特殊值
initial-scale 初始缩放比,大于0的数字
maximum-scale 最大缩放比,大于0的数字
minimum-scale 最小缩放比,大于0的数字
user-scalable 用户是否可以缩放,yes或no(1或0)

标准的viewport设置

  • 视口宽度和设备保持一致
  • 视口的默认缩放比例 1.0
  • 不允许用户自行缩放
  • 最大允许的缩放比例 1.0
  • 最小允许的缩放比例 1.0

二倍图

物理像素&物理像素比

  • 物理像素点指的是屏幕显示的最小颗粒,是物理真实存在的。这是厂商在出厂时就设置好了,比如苹果 6/7/8 是750*1334
  • 我们开发时候的 1px 不是一定等于1个物理像素的
  • PC端 页面,1个px 等于一个物理像素的,但是移动端不同
  • 一个px 能显示的物理像素点的个数,称为物理像素比或屏幕像素比

image-20231108082441860

  • PC端和早前的手机屏幕 / 普通手机屏幕:1CSS像素 = 1物理像素
  • Retina(视网膜屏幕)是一种显示技术,可以将把更多的物理像素点压缩至一块屏幕里,从而达到更高的分辨率,并提高屏幕显示的细腻程度

image-20231108082719007

多倍图

  • 对于一张 50px * 50px 的图片,在手机 Retina 屏中打开,按照刚才的物理像素比会放大倍数,这样会造成图片模糊
  • 在标准的 viewport 设置中,使用倍图来提高图片质量,解决在高清设备中的模糊问题
  • 通常使用二倍图,因为 iPhone 6/7/8 的影响,但是现在还存在3倍图4倍图的情况,这个看实际开发公司需求
  • 背景图片 注意缩放问题
/* 在 iphone8 下面 */
img{
    /* 原始图片 100 * 100px */
    width: 50px;
    height: 50px;
}
.box{
    /* 原始图片 100 * 100px */
	background-size: 50px 50px;
}

背景缩放 background-size

background-size 属性规定背景图像的尺寸

语法:

background-size: 背景图片宽度 背景图片高度;
  • 单位:长度 | 百分比 | cover | contain ;
  • cover 把背景图像扩展至足够大,以使背景图像完全覆盖背景区域
  • contain 把图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域

多倍图切图 cutterman

  • @3X 3倍图
  • @2X 2倍图
  • @1X 1倍图原图
image-20231108083639825

移动端技术解决方案

移动端浏览器

移动端浏览器基本以 webkit 内核为主,因此我们就考虑 webkit 兼容性问题

我们可以放心使用 H5 标签 和 CSS3样式

同时我们浏览器的私有前缀我们只需要考虑添加 webkit 即可

image-20231108084123984

CSS初始化 normalize.css

移动端CSS 初始化推荐使用 normalize.css/

  • Normalize.css :保护了有价值的默认值
  • Normalize.css :修复了浏览器的bug
  • Normalize.css :是模块化的
  • Normalize.css :拥有详细的文档

官网地址:http://necolas.github.io/normalize.css

CSS3盒子模型 box-sizing

  • 传统模式宽度计算:盒子的宽度 = CSS中设置的 width + border + padding
  • CSS3盒子模型:盒子的宽度 = CSS中设置的宽度 width 里面包含了 border 和 padding

也就是说,我们的CSS3中的盒子模型,padding 和 border 不会撑大盒子

/* CSS3盒子模型 */
box-sizing: border-box;
/* 传统盒子模型 */
box-sizing: content-box;

移动端可以全部应用CSS3盒子模型

PC端如果完全需要兼容,我们就用传统模式,如果不考虑兼容性,我们就选择 CSS3 盒子模型

特殊样式:

/* CSS3盒子模型 */
box-sizing: border-box;
-webkit-box-sizing: border-box;
/* 点击高亮我们需要清除 设置为 transparent 完成透明 */
-webkit-tap-highlight-color: transparent;
/* 在移动端浏览器默认的外观在iOS上加上这个属性才能给按钮和输入框自定义样式 */
-webkit-appearance: none;
/* 禁用长按页面时弹出的菜单 */
img,
a {
    -webkit-touch-callout: none;
}

移动端常见布局

单独制作移动端页面(主流)

  • 流式布局(百分比布局)
  • flex 弹性布局(强烈推荐)
  • less + rem + 媒体查询布局
  • 混合布局

响应式页面兼容移动端(其次)

  • 媒体查询
  • bootstrap

流式布局(百分比布局)

概述

  • 流式布局,就是百分比布局,也称非固定像素布局
  • 通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充
  • 流式布局方式是移动web开发使用的比较常见的布局方式
  • max-width :最大宽度(max-height 最大高度)
  • min-width :最小宽度(min-height 最小宽度)

案例-京东移动端首页

  1. 采用流式布局

  2. 搭建相关文件夹结构

  3. 设置视口标签以及引入初始化样式

    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" >
    
    <link rel="stylesheet" href="css/normalize.css" >
    <link rel="stylesheet" href="css/index.css" >
  4. 常用初始化样式

    body {
        margin: 0 auto;
        min-width: 320px;
        max-width: 640px;
        background: #ffffff;
        font-size: 14px;
        font-family: -apple-system, Helvetica, sans-serif;
        line-height: 1.5;
        color: #666;
    }
  5. 二倍精灵图做法

    • 在firework 里面把精灵图等比例缩放为原来的一半
    • 之后根据大小 测量坐标
    • 注意代码里面 background-size 也要写:精灵图原来宽度的一半
  6. 图片格式

    • DPG 图片压缩技术
    • webp 图片格式

flex布局

flex布局体验

传统布局与flex布局

传统布局

  • 兼容性好
  • 布局繁琐
  • 局限性,不能再移动很好的布局

flex弹性布局

  • 操作方便,布局极为简单,移动端应用很广泛
  • PC 端浏览器支持情况较差
  • IE 11或更低版本,不支持或仅部分支持

建议:

  1. 如果是PC端页面布局,还是传统布局
  2. 如果是移动端或者不考虑兼容性问题的PC端页面布局,还是使用flex弹性布局

初体验

HTML

<div>
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

css样式

div{
    display: flex;
    width: 500px;
    height: 500px;
    background-color: orange;
}
span{
    width: 100px;
    height: 100px;
    background-color: skyblue;
    border: 1px solid blue;
}

结果:

image-20231109224507472

布局原理

flex 是 flexible Box 的缩写,意为 “弹性布局”,用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为 flex 布局

  • 当我们为父盒子设为 flex 布局以后,子元素的 float、clear 和 vertical-align 属性将失效。
  • 伸缩布局 = 弹性布局 = 伸缩盒布局 = 弹性盒布局 = flex布局

采用 flex 布局的元素,称为 flex 容器,他的所有子元素自动成为容器成员,称为 flex 项目

  • 体验中 div 解释 flex 父容器
  • 体验中 span 就是子容器 flex 项目
  • 子容器可以横向排列也可以纵向排列

总结:

flex布局原理就是通过给父盒子添加 flex 属性,来控制子盒子的位置和排列方式

image-20231109225036626

父项常见属性

以下由 6个属性是对父元素设置的

  • flex-direction :设置主轴的方向
  • justify-content 设置主轴上的子元素排列方式
  • flex-wrap :设置子元素是否换行
  • align-content :设置侧轴上的子元素的排列方式(多行)
  • align-items :设置侧轴上的子元素排列方式(单行)
  • flex-flow :复合属性,相当于同时设置了 flex-direction 和 flex-wrap

flex-direction 设置主轴的方向

主轴与侧轴:

在 flex 布局中,是分为主轴和侧轴两个方向,同样的叫法有:行和列、x轴和y轴

  • 默认主轴方向就是 x轴 方向,水平向右
  • 默认侧轴方向就是 y轴 方向,水平向下
image-20231109225508743

属性值:

flex-direction 属性决定主轴的方向(即项目的排列方向)

注意:

主轴和侧轴是会变化的,就看 flex-direction 设置谁为值周,剩下的就是侧轴,而我们的子元素是跟着主轴来排列的

属性值 说明
row 默认值从左到右
row-reverse 从右到左
column 从上到下
column-reverse 从下到上
flex-start 默认值 从头部开始,如果主轴是x轴,则从左到右
flex-end 从尾部开始排列
center 在主轴居中对齐(如果主轴是x轴则 水平居中)
space-around 平分剩余空间
space-between 先两边贴边,在平分剩余空间(重要)

flex-wrap 设置子元素是否换行

默认情况下,项目都排在一条线(“轴线”)上。flex-wrap 属性定义,flex布局中默认是不换行的

属性值 说明
nowrap 默认值,不换行
wrap 换行

align-items 设置侧轴上的子元素排列方式(单行)

该属性是控制子项在侧轴(默认是y轴)上的排列方式,在子项为单项(单行)的时候使用

属性值 说明
flex-start 从上到下
flex-end 从下到上
center 挤在一起居中(垂直居中)
stretch 拉伸(默认值)

align-content 设置侧轴上的子元素的排列方式(多行)

设置子项在侧轴上的排列方式,并且只能用于子项出现 换行 的情况(多行),在单行下是没有效果的

属性值 说明
flex-start 默认值,从头部到尾部开始排列
flex-end 在侧轴的尾部开始排列
center 在侧轴中间显示
space-around 子项在侧轴平分剩余空间
space-between 子项在侧轴先分部在两头,再平分剩余空间
stretch 设置子项元素高度平分父元素高度

align-content 和 align-items 区别

  • align-items 适用于单行情况下,只要上对齐、下对齐、居中 和 拉伸
  • align-conten 适用于 换行(多行)的情况下(单行情况下无效),可以设置上对齐、下对齐、居中、拉伸以及平均分配剩余空间等属性
  • 总结就是单行找 align-items ,多行找 align-content

image-20231109231600996

flex-flow复合属性

flex-flow 属性是 flex-direction 和 flex-wrap 属性的复合属性

语法:

flex-flow: row wrap;

属性说明:

  • flex-direction :设置主轴的方向
  • justify-content :设置主轴上的子元素排列方式
  • flex-wrap :设置子元素是否换行
  • align-content :设置侧轴上的子元素的排列方式(多行)
  • align-items :设置侧轴上的子元素排列方式(单行)
  • flex-flow :复合属性,相当于同时设置了 flex-direction 和 wrap

flex布局子项常见属性

  • flex:份数 :表示子项目占的份数
  • align-self :控制子项自己在侧轴的排列方式
  • order属性定义子项的排列顺序(前后顺序)

flex属性

flex 属性定义子项目分配剩余空间,用 flex 来表示占多少份数

.item { 
    flex: <number>;  /* default 0 */
}

align-self :控制子项自己在侧轴上的排列方式

align-self 属性允许单个项目有与其他项目不一样的对齐方式,可覆盖 align-items 属性。

默认值为 auto,表示继承父元素的 align-items 属性,如果没有父元素,则等同于 stretch

span:nth-child(2){
    /* 设置自己在侧轴上的排列方式 */
    align-self: flex-end;
}

order属性定义项目的排列顺序

数值越小,排列越靠前,默认为 0

注意:和 z-index 不一样

.item {
    order: <number>;
}

案例-携程网首页

设置视口标签以及引入初始化样式:

<meta name="viewport" content="width=device-width, user-scalable=no, 
initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
 <link rel="stylesheet" href="css/normalize.css">
 <link rel="stylesheet" href="css/index.css">

常用初始化样式:

body {
    max-width: 540px;
    min-width: 320px;
    margin: 0 auto;
    font: normal 14px/1.5 Tahoma,"Lucida Grande",Verdana,"Microsoft
    Yahei",STXihei,hei;
    color: #000;
    background: #f2f2f2;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
}

常见flex布局思路:

image-20231109233011661

背景线性渐变:

background: linear-gradient(起始方向, 颜色1, 颜色2, ...);
background: -webkit-linear-gradient(left, red , blue);
background: -webkit-linear-gradient(left top, red , blue);

结果:

image-20231109233102403

背景渐变必须添加浏览器私有前缀

起始方向可以是:方位名词 或者 度数,如果省略默认就是 top

rem适配布局

rem基础

rem单位

rem(root rem)是一个相对单位,类似于em,em是父元素字体大小。

不同的是 rem 的基准是相对于 html 元素的字体大小。

比如,根元素(html)设置 font-size = 12px; 非根元素设置 width:2rem;则换成px表示就是24px。

rem的优势:父元素文字大小可能不一致,但是整个页面只有一个html,可以很好来控制整个页面的元素大小

/* 根html为12px */
html {
    font-size: 12px;
}
/* 此时div的文字大小就是 24px */ 
div {
    font-size: 2rem;
}

媒体查询

什么是媒体查询

媒体查询(Media Query)是 CSS3新语法

  • 使用 @media 查询,可以针对不同的媒体类型定义不同的样式
  • @media 可以针对不同的屏幕尺寸设置不能的样式
  • 当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面
  • 目前针对很多苹果手机、Android手机,平板等设备都用得到多媒体查询

语法规范

语法:

@media mediatype and|not|only(media feature) {
    CSS-code;
}

注意:

  • 用 @media 开头 注意 @符号
  • mediatype 媒体类型
  • 关键字 and not only
  • media feature 媒体特性 必须有小括号包含

mediatype查询类型

将不同的终端设备划分成不同的类型,称为媒体类型

解释说明
all 用于所有设备
print 用于打印机和打印预览
scree 用于电脑屏幕,平板电脑,智能手机等

关键字

关键字将媒体类型或多个媒体特性连接到一起作为媒体查询的条件

  • and:可以将多个媒体特性连接到一起,相当于 “且” 的意思
  • not:排除某个媒体类型,相当于 “非” 的意思,可以省略
  • only:指定某个特定的媒体类型,可以省略

媒体特性

每种媒体类型都具体各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。

解释说明
width 定义输出设备中页面可见区域的宽度
min-width 定义实处设备中页面最小可见区域宽度
max-width 定义输出设备中页面最大可见区域宽度

案例

根据页面宽度改变背景变色 (提倡从小到大来写)

实现思路:

  • 按照从大到小的或者从小到大的思路
  • 注意我们有最大值 max-width 和最小值 min-width 都是包含等于的
  • 当屏幕小于 540像素,背景颜色变为蓝色(x <= 539)
  • 当屏幕小于等于 540像素 并且小于等于 969像素的时候 背景颜色为 绿色(540 <= x <= 969)
  • 当屏幕大于等于970像素的时候,背景颜色为红色(x >= 970)

image-20231110083001877

媒体查询 + rem 实现元素动态大小变化

rem单位是跟着html来走的,有了rem页面可以设置不同大小尺寸

媒体查询可以根据不同设备宽度来修改样式

媒体查询 + rem 就可以实现不同设备宽度,实现页面元素大小的动态变化

image-20231110083322467

当样式比较繁多的时候,我们可以针对不同的媒体使用不同 stylesheets(样式表)

原理,就是直接在 link 中判断设备的尺寸,然后引用不同的 css文件

语法规范:

<link rel=">stylesheet" media="mediatype and|not|only (media feature)" href="mystylesheet.css">

示例:

<link rel="stylesheet" href="styleA.css" media="screen and (min-width: 400px)">

Less基础

维护css的弊端

css是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念

  • CSS 需要书写大量看似没有逻辑的代码,CSS 冗余度是比较高的。
  • 不方便维护及扩展,不利于复用
  • CSS没有很好的计算能力
  • 非前端开发工程师来讲,往往会因为缺少CSS编写经验而很难写出组织良好且易于维护的CSS代码项目。

Less介绍

Less(Leaner Style Sheets)是一门CSS扩展语言,也称为CSS预处理器。

作为CSS的一种形式的扩展,它并没有减少CSS的功能,而是在现有的CSS语法上,为CSS加入程序式语言的特性。

它在CSS的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了CSS的编写,并且降低了CSS的维护成本,Less可以让我们用更少的代码做更多的事情。

Less中文网址:http://lesscss.cn

常见的CSS预处理器:Sass、Less、Stylus

Less是一门CSS与处理语言,它扩展了CSS的动态特性。

Less安装

如果使用 vscode 则无需安装Less

  1. 安装 nodejs ,可选择版本8.0,网址:http://nodejs.cn/download
  2. 检查是否安装成功,使用 cmd 命令,输入node -v 查看版本即可
  3. 基于 nodejs 在线安装 Less,使用 cmd命令 npm install -g less 即可
  4. 检查是否安装成功,使用 cmd命令 lessc -v 查看版本即可

Less使用

首先新建一个后缀名为less的文件,在这个less文件里面书写 less 语句。

  • less变量
  • less编译
  • less嵌套
  • less运算

Less变量

变量是指没有固定的值,可以改变的。因为我们CSS中的一些颜色和数值等经常使用。

@变量名:;

变量命名规范

  • 必须有@为前缀
  • 不能包含特殊字符
  • 不能以数字开头
  • 大小写敏感
@color: pink;

变量使用规范

/* 直接使用 */
body {
    color: @color;
}
a:hover{
    color: @color;
}

Less编译

本质上,Less包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的CSS文件

所以,我们需要把我们的 less 文件,编译生成为 css 文件,这样我们的html页面才能使用。

插件:Easy LESS ,自动生成css文件

Less嵌套

我们经常用到选择器的嵌套,css写法

#header .log{
    width: 300px;
}

Less嵌套写法

#header{
    .logo{
        width: 300px;
    }
}

如果遇见 (交集 | 伪类 | 伪元素选择器)

  • 内层选择器的前面没有 & 符号,则它被解析为负选择器的后代;
  • 如果有 & 符号,它就被解析为父元素自身或父元素的伪类

css写法:

a:hover{
    color: red;
}

Less嵌套写法

a{
    &:hover{
        color: red;
    }
}

Less运算

任何数字、颜色或者变量都可以参与运算。就是 Less提供了加(+)、减(-)、乘(*)、除(/)算数运算

/* Less里面写 */
@width: 10px + 5;    //15px
div {
    border: @width solid red;
}

/* 生成的css */
div {
    border: 15px solid red;
}

/* Less 甚至可以这样写 */
width: (@width + 5) * 2;

注意:

  • 乘号(*) 和 除号(/) 的写法
  • 运算符中间左右有个空格隔开 1px + 5
  • 对于两个不同的单位的值之间的运算,运算结果的值取第一个值的单位
  • 如果两个值之间只有一个值有单位,则运算结果就取该单位

rem适配方案

  • 让一些不能等比自适应的元素,达到当设备尺寸发生改变的时候,等比例适配当前设备
  • 使用媒体查询根据不同设备按比例设置 html 的字体大小,然后页面元素使用 rem 做尺寸单位,当html字体大小变化元素尺寸也会发生变化,从而达到等比缩放的适配

rem实际开发适配方案

  1. 按照设计稿与设备宽度的比例,动态计算并设置 html 根标签的 font-size 大小;(媒体查询)
  2. CSS中,设计稿元素的宽、高、相对位置等取值,按照同等比例换算为 rem 为单位的值

rem实际开发适配方案

技术方案1:

  • less
  • 媒体查询
  • rem

技术方案2:(推荐)

  • flexible.js
  • rem

方案1

rem + 媒体查询 + less技术

设计稿常见尺寸宽度

image-20231110090534859

一般情况下,我们以一套或两套效果图适应大部分的屏幕,放弃极端屏或对其优雅降级,牺牲一些效果,现在基本以750为准

动态设置 html 标签 font-size 大小

  1. 假设设计稿是 750px
  2. 假设我们把整个屏幕划分为 15等份 (划分标准不一 可以是20等份也可以是10等份)
  3. 每一份作为html字体大小,这里就是50px
  4. 那么在 320px 设备的时候,html字体大小就是 320/15 就是21.33px
  5. 用我们页面元素的大小 除以 不同的html字体大小会发现他们比例还是相同的
  6. 比如我们以 750为标准设计稿
  7. 一个 100 * 100 像素的页面元素在 750屏幕下,就是 100 / 50 转换为 rem 是 2rem * 2rem 比例是 1比1 (因为每一份是50px,即1rem = 50px,所以100px 就是 2rem)
  8. 但是已经能实现不同屏幕下,页面元素盒子等比例缩放的效果

元素大小取值方法

  • 最后的公式: 页面元素的rem值 = 页面元素值(px) / (屏幕宽度 / 划分的分数)
  • 屏幕宽度 / 划分的份数 就是 html 的font-size 的大小
  • 或者:页面元素的rem值 = 页面元素值(px) / html的font-size 字体大小

响应式布局

响应式开发

响应式开发原理

就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的

image-20231113080108958

响应式布局容器

响应式需要一个父级作为布局容器,来配合子级元素来实现变化。

原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,再改变里面子元素的排列方式和大小,从而实现不同屏幕下,看到不同页面布局和样式变化

平时我们的响应式尺寸划分

  • 超小屏幕(手机,小于768px):设置宽度为 100%
  • 小屏幕(平板,大于992px):设置宽度为 750px
  • 中等屏幕(桌面显示器,大于等于 992px):宽度设置为 970px
  • 大屏幕(大桌面显示器,大于等于 1200px):宽度设置为 1170px
  • 我们也可以根据实际情况自己定义划分

Bootstrap前端开发框架

Bootstrap 是基于 HTML、CSS 和 JavaScript 的,它简洁灵活,使得 Web 开发更加快捷

bootstrap简介

优点:

  • 标准化的 html + css 编码规范
  • 提供了一套简洁、直观、强悍的组件
  • 有自己的生态圈,不断的更新迭代
  • 让开发更简单,提高了开发的效率

版本:

  • 2.x.x :停止维护,兼容性号,代码不够简洁,功能不够完善
  • 3.x.x :目前使用最多,稳定,但是放弃了 IE6-IE7。对 IE8 支持但是界面效果不好,偏向于开发响应式布局,移动设备有限的 Web 项目
  • 4.x.x :最新版,目前还不是很流行

bootstrap使用

  1. 创建文件夹结构
  2. 创建 html 骨架结构
  3. 引用相关样式文件
  4. 书写内容

创建html骨架结构:

<!-- 要求当前网页使用IE浏览器最高版本的内核来渲染 -->
<meta http-equiv="X-UA-Compatible" content="IE-edge">

<!-- 视口的设置:视口的宽度和设备一致,默认的缩放比例和PC端一致,用户不能自行缩放 -->
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0">

<!--[if lt IE 9]>
	<!-- 解决ie9以下浏览器对html5新增标签的不识别,并导致CSS不起作用的问题 -->
<script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<script src="http://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->

引入相关样式文件

<!-- bootstrap 核心样式 -->
<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">

<!-- bootstrap JS-->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/js/bootstrap.min.js"></script>

书写内容

  • 直接拿 bootstrap 预先定义好的样式来使用
  • 修改 bootstrap 原来的样式,注意权重问题
  • 学好 bootstrap 的关键在于知道它定义了哪些样式,以及这些样式能实现什么样的效果

布局容器

bootstrap 需要为页面内容和栅格系统包裹一个 container 容器,它提供了两个作此作用处的类。

container类

  • 响应式布局的容器,固定宽度
  • 大屏( >= 1200px)宽度定为 1170px
  • 中屏( >= 992px) 宽度定为 970px
  • 小屏 ( >= 768px) 宽度定为 750px
  • 超小屏(100%)

container-fluid类

  • 流式容器布局 百分百宽度
  • 占据全部视口 (viewport)的容器

Bootstrap栅格系统

栅格系统简介

栅格系统是将页面布局划分为等宽的列,然后通过列数的定义来模块化页面布局

bootstrap提供了一套响应式、移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多 12列

栅格选项参数

栅格系统用于通过一系列的行(row)与列(column)的组合来创建页面布局,你的内容就可以放入这些创建好的布局中

image-20231113092056473

说明:

  • 按照不同屏幕划分为 1-12 等份
  • 行(row)可以去除父容器作用 15px 的边距
  • xs-extra small :超小;sm-small:小; md-medium:中等;lg-large:大;
  • 列(column)大于 12,多余的 ‘列’ ,所在的元素将被作为一个整体另起一行排列
  • 每一列默认有左右 15px 的padding
  • 可以同时为一列指定多个设备的类名,以便划分不同份数,例如 class="col-md-4 col-sm-6"

列嵌套

栅格系统内置的栅格系统将内容再次嵌套。简单理解就是一个列内在分成若干份小列。我们可以通过添加一个新的 .row 元素和一系列 .col-sm-* 元素到已经存在的 .col-sm-* 元素内。

image-20231113092756120

列偏移

使用 .col-md-offset-* 类可以将列向右侧偏移。这些类实际是通过使用 * 选择器为当前元素增加了左侧的边距(margin)。

image-20231113093020856

列排序

通过使用 .col-md-push-*.col-md-pull-* 类就可以很容易的改变列(column)的顺序。

image-20231113093124453

响应式工具

为了加快对移动设备友好的页面开发工作,利用媒体查询功能,并使用这些工具类可以方便的针对不同设备展示或隐藏页面内容。

image-20231113093234620

案例-阿里百秀

container 宽度修改

本效果图采取 1280的宽度,而 bootstrap 里面 container 宽度最大为 1170px,因此我们需要手动改下 container 宽度。

@media (min-width: 1280px){
    .container {
        width: 1280px;
    }
}