移动端常见布局

移动端技术选型

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

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

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

  • 媒体查询
  • bootstrap

一、流式布局(百分比布局)

流式布局,就是百分比布局,也称非固定像素布局

通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充

流式布局方式是移动Web开发使用的比较常见的布局方式

max-width(max-height)最大宽度

min-width(min-height)最小宽度

 二倍精灵图做法

1.在PS中把精灵图等比例缩放为原来的一半

2.之后根据大小测量坐标

3.注意代码里面background-size也要写:精灵图原来宽度的一半

二、flex布局体验

传统布局与flex布局

【传统布局】

  • 兼容性好
  • 布局繁杂
  • 局限性,不能在移动端很好地布局

【flex布局】

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

建议:

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

布局原理

flex是flexible Box的缩写,意为“弹性组件”,为盒状模型提供最大的数量,任何一个容器都可以为flex布局指定。

  • 当我们为父盒子设为 flex 布局以后,子元素的float(浮动)、clear(清除)和vertical-align(垂直对齐)属性将失效。
  • 弹性布局=弹性布局=弹性组件布局=弹性组件布局=flex布局

采用flex布局的元素,称为flex容器(flex container),简称“容器”。 

它的所有子元素自动成为容器成员 ,称为Flex项目(flex item),简称“项目”。

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

【总结flex布局原理】

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

 flex组件父项常见属性

常见父项属性

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

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

 1、flex-direction设置主轴的方向  ¤

 (1)主轴与侧轴

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

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

(2)属性值

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

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

属性值说明
row从左到右(默认值)
row-reverse从右到左
column从上到下
column-reverse从下到上

2、 justify-content设置主轴上的子元素排列方式  ¤

justify-content 属性定义了项目在主轴上的对齐方式

注意:使用这个属性之前一定要确定好主轴是哪个!

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

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

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

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

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

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

属性值说明
flex-start从上到下
flex-end从下到上
center挤在一起居中(垂直居中)
stretch拉伸(默认值)注:前提是子盒子没有指定的高度,否则没有效果!

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

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

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

align-content和align-items的区别 

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

6、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 和 flex-wrap

flex布局子项常见属性

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

1、flex属性  ¤

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

. 项目{flex: <number > ; /* 默认 0 */ 
}

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

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

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

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

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

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

注意:和 z-index 不一样。

. 项目{order:<编号>; /* 默认是0 */
}

三、rem适配布局

【思考】

  1. 页面布局能否随着屏幕大小变化而变化?
  2. 流式布局和flex布局主要针对于宽度布局,那高度如何设置?
  3. 怎么样让屏幕发生变化的时候元素高度和宽度等比例缩放?

1、rem 单位

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

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

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

页面只有一个html,可以很好地控制整个页面的元素大小.(即:达到统一控制字体大小的效果!)

注意:rem 控制的字体大小,可以控制其他元素的大小。

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

注:虽然使用 rem 之后实现了字体大小的统一控制,但仍然无法根据图片大小自动适配,所以我们还需要学习媒体查询。 

2、媒体查询

媒体查询(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定义输出设备中页面最大可见区域的宽度

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

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

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

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

4、引入资源(理解)

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

比如:从PC端样式变移动端样式时,最好单独写样式表

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

(1)语法规范

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

(2)实例

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

CSS弊端及Less的应用

1、维护CSS的弊端

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

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

2、Less介绍

Less(Leaner Style Sheets 的缩写)是一门 CSS 扩展语言,也就是 CSS 预处理器。

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

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

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

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

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

3、Less使用

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

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

4、Less变量

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

@变量名: 值;

① 变量命名规范

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

② 变量使用规范 

//直接使用
body {color : @color ;
}div {color:@color ;
}

5、Less编译

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

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

 6、Less编码

① Less嵌套  子元素的样式直接写到父元素里面就好了 

@color: skyblue;
@colorpur: purple;
@font14: 14px;
@font16: 16px;.box {color: @color;font-size: @font14;a {color: @colorpur;font-size: @font16;}
}

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

  • 内层选择器的前面没有&符号,则它被解析为父选择器的后代
  • 如果有&符号,它就被解析为父元素自身或父元素的伪类
a {color: @colorpur;font-size: @font16;&:hover {color: burlywood;}}

7、Less运算  ¤

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

/*less里面写*/@width : 10 px  +  5 ;div {border:@width solid red;
}/*生成的css*/div {border: 15px solid red;
}/*less甚至还可以这样*/width : ( @width  +  5 ) *  2 ;

注意:

  • 乘号(*)和除号(/)的写法要牢记
  • 运算符左右两侧要有个空格隔开 1px + 5
  • 在新版本的少中,除法有改动,应100px / 10改为(100px / 10),否则没有效果
  • 对于两个不同的单位的值之间的运算,运算结果的值取第一个值的单位
  • 如果两个值之间只有一个值有单位,则运算结果就取该单位

rem适配方案

【思考】

  1. 我们适配的目标是什么?
  2. 怎么去达到这个目标的?
  3. 在实际的开发中如何实现?

【答案】

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

rem 实际开发适配方案

(1)按照设计稿与设备宽度的比例,动态计算并设置html根标签的 font-size 大小;(媒体查询)。

(2)CSS中,设计稿元素的宽、高、相对位置等取值,按照同等比列换算为rem为单位的值。

rem适配方案技术使用(市场主流)

(1)技术方案1

  • less
  • 媒体查询
  • rem

(2)技术方案2(推荐)

  • flexible.js
  • rem

总结:

  1. 两种方案的原理都一样的
  2. 两种方案目前都在使用
  3. 方案2 更简单,现阶段大家无需了解里面的js代码

1、rem实际开发适配方案1

rem + 媒体查询 + less技术

 (1)设计稿常见尺寸宽度

设备常见宽度
苹果手机 4 5640 像素
苹果手机 6 7 8750 像素
苹果 x 11 121170 像素
安卓常见 320px、360px、375px、384px、400px、414px、500px、720px、1080px

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

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

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

(3)元素大小取值方法

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

2、rem适配方案2

简洁高效的rem适配方案flexible.js

手机淘宝团队出的简洁高效的移动端适配库

我们再也不需要在写不同屏幕的媒体查询,因为里面的 js 可以处理

它的原理是把当前设备划分为10等份,但不同的设备下,比例还是一致的

我们要做的,就是确定好我们当前设备的html文字大小就可以了

比如当前设计稿是750px,那么我们只需要把html文字大小设置为75px(750px / 10)就可以了

里面页面元素rem值:页面元素的px值 / 75

生育的,让flexible.js来去算

github地址:https://github.com/amfe/lib-flexible/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/31613.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端常用的几种布局方式(推)

布局 静态布局:布局特点&#xff1a;设计方法:PC :移动端&#xff1a; 优点&#xff1a;缺点&#xff1a; 流式布局&#xff1a;布局特点&#xff1a;设计方法&#xff1a;缺点&#xff1a; 自适应布局&#xff1a;布局特点&#xff1a;设计方法&#xff1a; 响应式布局:布局特…

【前端布局篇】响应式布局 Bootstrap 移动端布局

前言 1. 布局介绍 布局:layout 对事物的全面规划和安排 页面布局&#xff1a;对页面的文字、图形或表格进行格式设置。包括字体、字号、颜色纸张大小和方向以及页边距等。 网页布局&#xff1a;利用html搭建结构与内容&#xff0c;使用CSS添加装饰 HTML5CSS3系列课程 携程…

分析前端页面常见布局排版

首先我们先关注显示器 显示器的分辨率问题很大程度影响页面最后的渲染展示效果; 常见的显示器分辨率: 1024*600 (文物 大屁股显示器) 1280*1024 (1% 用户 正方形显示器 即将灭绝) 1366*768(30% 用户 其中有20%的笔记本用户是从1920*1080的分辨率系统放大过来的) 1440*900…

迷雾:我们是否拥有自己的数据?

从上世纪 60 年代个人电脑出现到现在&#xff0c;数字世界已经深入到我们生活的点点滴滴&#xff0c;从微小 “数字细胞” 到庞大概念的 “元宇宙”。ChatGPT 的火热也再次我们感受到强大的数字力量&#xff0c;甚至很多人都在思考如何改变才能避免工作上被替代。但是在数字世界…

硅图并购 MIPS | 历史上的今天

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2023 年 6 月 29 日&#xff0c;在 2008 年的今天&#xff0c;CNNIC 发布《第 22 次中国互联网络发展状况统计报告》&#xff0c;截至 2008 年 6 月底&#xff0c;中国网…

苹果推出 Mac OS X | 历史上的今天

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2023 年 3 月 24 日&#xff0c;在 2016 年的今天&#xff0c;暴雪娱乐公司发布了第一人称射击多人游戏《守望先锋》。根据评分汇总网站 Metacritic 的统计&#xff0c;…

iPhone 3G 发布 | 历史上的今天

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2023 年 6 月 9 日&#xff0c;在 2004 年的今天&#xff0c;第 28 届雅典奥运会的圣火在中国北京举行火炬传递仪式&#xff0c;传递路线以天安门为起点&#xff0c;途径…

吴军:阅读与写作50讲01

作业&#xff1a; 时间&#xff1a;未说明 人物&#xff1a;追求美丽女子的男人及该名美丽的女子。文章是从一个男人的角度去讲述一个女子的美丽与贤良。 地点&#xff1a;具体没讲&#xff0c;但通过河边的景物衬托女子的美好。男子可能在河边观察女子&#xff0c;并掀起心中的…

吴军给大学生的书单

文章目录 第一类、经典1.《庄子》A2.《孟子》A3.《史记》A4.《圣经》B5.《论法的精神》A6.《社会契约论》B7.《路德维希费尔巴哈和德国古典哲学的终结》B8. 《查拉斯图拉如是说》和《偶像的黄昏》B9.《宋词300首》A10.《元曲300首》B 第二类、东方文学1.《水浒传》A2.《牡丹亭》…

吴军:区块链催生了新的生产关系

吴军是人工智能方面的专家&#xff0c;他认为&#xff0c;我们今天已经进入一个超级智能时代。在这个超级智能时代&#xff0c;下一代互联网的核心&#xff0c;很有可能是区块链。10月份&#xff0c;在上海交大EMBA的创业训练营上&#xff0c;吴军做了一场有关区块链技术的演讲…

《吴军信息论40讲》学习笔记(完)

00.发刊词 信息时代的最大特征是不确定性。 信息论是人类对抗不确定性&#xff0c;最重要和有效的方法论。 20世界初概率论和统计学的成熟&#xff0c;使人们得以把握随机性。在此基础上&#xff0c;1948年&#xff0c;香农博士找到了不确定性和信息的关系&#xff0c;从此为人…

《前沿科技·吴军讲5G》思维导图详细解析

信息技术的不断发展为人类发展提供了力量与能量&#xff0c;力量给予社会各项发展前进的动力&#xff0c;能量给予各种技术不断的创新迭代。那么移动通信技术从最开始的语音服务&#xff0c;到数据服务再到金融等其他领域的服务&#xff0c;经历了从1G到4G的不断迭代与与升级&a…

吴军《知识、智慧和能力》

人但凡要生活得好&#xff0c;工作有成就&#xff0c;总是离不开这三样东西——知识、智慧和能力。 知识的作用自不消说。1597年&#xff0c;英国著名的政治家和哲学家培根在他的著作《沉思录》中喊出了“知识就是力量”这个让人振聋发聩的口号。今天&#xff0c;追求知识已经…

计算机吴军科学家个人故事,吴军:阅读与写作50讲+吴军个人成长书单

吴军 约翰霍普金斯大学计算机科学博士、计算机科学家、硅谷投资人、著名自然语言处理和搜索专家。 畅销书《浪潮之巅》《数学之美》《文明之光》《大学之路》《硅谷之谜》《智能时代》《见识》《态度》作者。 吴军:阅读与写作50讲吴军个人成长书单 课程亮点&#xff1a; 1. 职场…

终于!我们把 CEO 炒了,让 ChatGPT 出任 CEO

⚠️ FBI Warning&#xff1a;本文纯属作者自娱自乐&#xff0c;数字人的观点不代表 CEO 本人的观点&#xff0c;请大家不要上当受骗&#xff01;&#xff01; 哪个公司的 CEO 不想拥有一个自己的数字克隆&#xff1f; 想象&#x1f914;一下&#xff0c;如果 CEO 数字克隆上线…

chatgpt赋能python:Python冒泡排序法详解

Python冒泡排序法详解 介绍 Python是一种高级编程语言&#xff0c;它设计简洁、易于学习&#xff0c;受到越来越多程序员的欢迎。 在Python编程中&#xff0c;排序算法是非常重要的一部分。其中&#xff0c;冒泡排序法是一种纯粹的比较排序算法&#xff0c;它是大多数排序算…

chatgpt赋能python:Python冒泡排序:从入门到精通

Python冒泡排序&#xff1a;从入门到精通 冒泡排序是一种简单且实用的排序算法&#xff0c;Python也可以轻松地实现冒泡排序。在本文中&#xff0c;我们将逐步介绍Python中如何编写冒泡排序。 什么是冒泡排序 冒泡排序是一种基于比较的排序算法。其基本思想是从列表中的第一…

chatgpt赋能python:Python冒泡排序算法详解

Python 冒泡排序算法详解 在计算机科学中&#xff0c;排序算法是一种将数据元素按照一定顺序排序的算法。其中&#xff0c;冒泡排序是最基础和最常用的排序算法之一&#xff0c;也是 python 中最容易实现的排序算法之一。在这篇文章中&#xff0c;我们将通过介绍 python 中的冒…

chatgpt赋能python:Python实现冒泡排序——让列表排序变得简单

Python实现冒泡排序——让列表排序变得简单 如果你常常处理数据&#xff0c;并需要按照一定顺序排列它们&#xff0c;那么你一定需要掌握一种快速、高效的排序算法——冒泡排序。冒泡排序是一种基础排序算法&#xff0c;也是最常用的排序之一。现在&#xff0c;我们来探究一下…

chatgpt赋能Python-python3冒泡排序代码

Python3 冒泡排序代码 什么是冒泡排序&#xff1f; 冒泡排序是一种简单的排序算法。它重复地遍历要排序的列表&#xff0c;比较相邻的两个元素&#xff0c;并根据大小交换它们的位置。如果需要&#xff0c;则重复执行该过程&#xff0c;直到整个列表都已排序。 冒泡排序的实…