CSS3网页布局基础

CSS布局始于第2个版本,CSS 2.1把布局分为3种模型:常规流、浮动、绝对定位。CSS 3推出更多布局方案:多列布局、弹性盒、模板层、网格定位、网格层、浮动盒等。本章重点介绍CSS 2.1标准的3种布局模型,它们获得所有浏览器的全面、一致性的支持,被广泛应用。

1、流动布局

在默认状态下,HTML文档将根据流动模型进行渲染,所有网页对象自上而下按顺序动态呈现。改变HTML文档的结构,网页对象的呈现顺序就会发生变化。

流动布局的优点:元素之间不会存在错位、覆盖等问题,布局简单,符合浏览习惯;流动布局的缺点:网页布局样式单一,网页版式缺乏灵活性。

流动布局有如下特征:

  • 块状元素自上而下按顺序垂直堆叠分布。块状元素的宽度默认为100%,占据一行显示。
  • 行内元素从左到右遵循文本流进行分布,超出一行后,会自动换行显示。

【示例】设计在页面中添加多个对象,浏览器都会自上向下地逐个解析并显示所有网页对象:

    <div id="contain"><h2>标题元素</h2><p>段落元素</p><ul><li>列表项</li></ul><table><tr><td>表格行,单元格</td><td>表格行,单元格</td></tr></table></div>

在这里插入图片描述

2、浮动布局

浮动布局能够实现块状元素的并列显示,允许浮动元素向左或向右停靠,但不允许脱离文档流,依然受文档结构的影响。

浮动布局的优点:相对灵活,可以并列显示;
浮动布局的缺点:版式不稳固,容易错行、重叠。

2.1、定义浮动显示

在默认情况下,任何元素都不具有浮动特性,可以使用CSS的float属性定义元素向左或向右浮动,具体语法格式如下:

    float:none | left | right

取值left表示元素向左浮动,right表示元素向右浮动,none表示消除浮动,默认值为none。

浮动布局有如下特征:

  • 浮动元素以块状显示。如果浮动元素没有定义宽度和高度,它会自动收缩到仅能包住内容为止。如果浮动元素内部包含一张图片,则浮动元素将与图片一样宽;如果包含的是文本,则浮动元素将与最长文本行一样宽。而块状元素如果没有定义宽度,则显示为100%。
  • 浮动元素与流动元素可以混用,不会重叠,二者都遵循先上后下的显示顺序,受文档流影响。
  • 浮动元素仅能改变水平显示顺序,不能改变垂直显示方式。浮动元素不会强制前面的流动元素环绕其周围流动,而总是换行浮动显示。
  • 浮动元素可以并列显示,如果宽度不够,则会换行显示。

【示例】设计3个并列显示的方块,通过float定义左、中、右3栏并列显示:

    <style type="text/css">body {padding: 0; margin: 0; text-align: center;}#main {                                           /*定义网页包含框样式*/width: 400px;margin: auto;padding: 4px;line-height: 160px;color: #fff;font-size: 20px;border: solid 2px red;}#main div {float: left;height: 160px;}            /*定义三个并列栏目向左浮动显示*/#left {width: 100px;background: red;}             /*定义左侧栏目样式*/#middle {width: 200px;background: blue;}          /*定义中间栏目样式*/#right {width: 100px; background: green;}         /*定义右侧栏目样式*/.clear { clear: both; }</style><div id="main"><div id="left">左侧栏目</div><div id="middle">中间栏目</div><div id="right">右侧栏目</div><br class="clear" /></div>

在这里插入图片描述
注意:浮动布局可以设计多栏并列显示效果,但也容易错行,如果浏览器窗口发生变化,或者包含框的宽度不固定,则会出现错行显示问题,破坏并列布局效果。

2.2、清除浮动

使用CSS的clear属性可以清除浮动,定义与浮动相邻的元素在必要的情况下换行显示,这样可以控制浮动元素同时挤在一行内显示。clear属性取值包括以下4个:

  • left:清除左边的浮动元素,如果左边存在浮动元素,则当前元素会换行显示。
  • right:清除右边的浮动元素,如果右边存在浮动元素,则当前元素会换行显示。
  • both:清除左右两边的浮动元素,不管哪边存在浮动对象,则当前元素都会换行显示。
  • none:默认值,允许两边都可以存在浮动元素,当前元素不会主动换行显示。

【示例】设计一个简单的3行3列页面结构,设置中间3栏平行浮动显示:

    <style type="text/css">div {border: solid 1px red;         /* 增加边框,以方便观察 */height: 50px;                  /* 固定高度,以方便比较 */}#left, #middle, #right {float: left;                   /* 定义中间3栏向左浮动 */width: 33%;                    /* 定义中间3栏等宽 */}</style><div id="header">头部信息</div><div id="left">左栏信息</div><div id="middle">中栏信息</div><div id="right">右栏信息</div><div id="footer">脚部信息</div>

在这里插入图片描述
如果设置左栏高度大于中栏和右栏高度,则发现脚部信息栏上移并环绕左栏右侧:

    #left {height:100px; }  /* 定义左栏高出中栏和右栏 */

在这里插入图片描述
如果为

    #footer { clear:left; }              /* 为脚部栏目元素定义清除属性 */

在这里插入图片描述
提示:Clear主要针对float属性起作用,对左右两侧浮动元素有效,对于非浮动元素是无效的。

3、定位布局

定位布局允许精确定义网页元素的显示位置,可以相对原位置,也可以相对定位框,或者是相对视图窗口。

定位布局的优点:精确定位;
定位布局的缺点:缺乏灵活性。

3.1、定义定位显示

使用position属性可以定义元素定位显示,具体语法格式如下:

    position:static | relative | absolute | fixed

取值说明如下:

  • static:表示静态显示,非定位模式。遵循HTML流动模型,为所有元素的默认值。
  • absolute:表示绝对定位,将元素从文档流中脱离出来,可以使用left、right、top、bottom属性进行定位,定位参照最近的定位框。如果没有定位框,则参照窗口左上角。定位元素的堆放顺序可以通过z-index属性定义。
  • fixed:表示固定定位,与absolute定位类型类似,但它的定位框是视图本身,由于视图本身是固定的,它不会随浏览器窗口的滚动而变化,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。
  • relative:表示相对定位,通过left、right、top、bottom属性设置元素在文档流中的偏移位置。元素的形状和原位置保留不变。

3.2、相对定位

相对定位将参照元素在文档流中的原位置进行偏移。

【示例】定义strong元素对象为相对定位,然后通过相对定位调整标题在文档顶部的显示位置:

<!DOCTYPE html>
<html><head><style type="text/css">p { margin: 60px; font-size: 14px;}p span { position: relative; }p strong {/*[相对定位]*/position: relative;left: 40px; top: -40px;font-size: 18px;}</style></head><body><p> <span><strong>虞美人</strong>南唐\宋 李煜</span> <br>春花秋月何时了?<br>往事知多少。<br>小楼昨夜又东风,<br>故国不堪回首月明中。<br>雕栏玉砌应犹在,<br>只是朱颜改。<br>问君能有几多愁?<br>恰似一江春水向东流。</p></body><script></script>
</html>

在这里插入图片描述
通过下图可以看到,偏移之后,元素原位置保持不变。
在这里插入图片描述

3.3、定位框

定位框与包含框是两个不同的概念,定位框是包含框的一种特殊形式。从HTML结构的包含关系来说,如果一个元素包含另一个元素,那么这个包含元素就是包含框。包含框可以是父元素,也可以是祖先元素。

如果一个包含框被定义了相对定位、绝对定位或者固定定位,那么它不仅是一个包含框,也是一个定位框。定位框的主要作用是为被包含的绝对定位元素提供坐标偏移参考。

3.4、层叠顺序

定位元素可以层叠显示,类似Photoshop的图层模式,这样就容易出现网页对象相互遮盖现象。如果要改变元素的层叠顺序,可以定义z-index属性。如果取值为正整数,数字越大,则优先显示出来;如果取值为负数,数字越大,则优先被遮盖。

3.5、案例:设计定位模板页

<!DOCTYPE html>
<html><head><style type="text/css">body {                           /*定义窗体属性*/margin: 0;                   /*清除IE默认边距*/padding: 0;                  /*清除非IE默认边距*/text-align: center;          /*设置在IE浏览器中居中对齐*/}#contain {                       /*定义父元素为相对定位,实现定位框*/width: 100%;                 /*定义宽度*/height: 310px; /*必须定义父元素的高度,该高度应大于绝对布局的最大高度,否则父元素的背景色就无法显示,且后面的布局区域也会无法正确显示*/position: relative;          /*定义为相对定位*/background: #E0EEEE;margin: 0 auto;              /*非IE浏览器中居中显示*/}#header, #footer {               /*定义头部和脚部区域属性,以默认的流动模型布局*/width: 100%;height: 50px;background: #C0FE3E;margin: 0 auto;              /*非IE浏览器中居中显示*/}#sub_contain1 {                  /*定义左侧子元素为绝对定位*/width: 30%;                  /*根据定位框定义左侧栏目的宽度*/position: absolute;          /*定义子栏目为绝对定位*/top: 0;                      /*在定位框顶边对齐*/left: 0;                     /*在定位框左边对齐*/height: 300px;               /*定义高度*/background: #E066FE;}#sub_contain2 {                  /*定义右侧子元素为绝对定位*/width: 70%;                  /*根据定位框定义右侧栏目的宽度*/position: absolute;          /*定义子栏目为绝对定位*/top: 0;                      /*在定位框顶边对齐*/right: 0;                    /*在定位框右边对齐*/height: 200px;               /*定义高度*/background: #CDCD00;}</style></head><body><div id="header">标题栏</div><div id="contain"><div id="sub_contain1">左栏</div><div id="sub_contain2">右栏</div></div><div id="footer">页脚</div></body><script></script>
</html>

在这里插入图片描述
在上面示例中,设计左右栏(<div id="sub_contain1">、<div id="sub_contain2">)绝对定位显示,两栏包含框(<div id="contain">)为相对定位显示,这样左右栏就以包含框为定位参照。

由于定位框(<div id="contain">)的高度不会跟随子元素(<div id="sub_contain1">、<div id="sub_contain2">)的高度自适应调整,因此要实现合理布局,必须给父元素(<div id="contain">)定义一个固定高度,这样才能显示中间行的背景,页脚栏目(<div id="footer">)才会跟随其后正常显示。

注意:本例设计思路的前提条件是必须确保左右栏(<div id="sub_contain1"><div id="sub_contain2">)的高度是固定的。如果是动态内容,就不应该采用本节模板进行设计。

4、案例实战

假设有如下文档主结构固定不变,将练习使用CSS设计不同的呈现版式:

    <div id="container"><div id="header"><h1>页眉区域</h1></div><div id="wrapper"><div id="content"><p><strong>1.主体内容区域</strong></p></div></div><div id="navigation"><p><strong>2.导航栏</strong></p></div><div id="extra"><p><strong>3.其他栏目</strong></p></div><div id="footer"><p>页脚区域</p></div></div>

在这里插入图片描述

4.1、设计固宽+弹性页面

本案例版式设计导航栏与其他栏目并为一列固定在右侧,主栏以弹性方式显示在左侧,实现主栏自适应页面宽度变化而侧栏宽度固定不变的版式效果,结构设计如下图所示:
在这里插入图片描述
本示例的样式代码如下:

    div#wrapper {                           /* 主栏外框 */float:left;                         /* 向左浮动 */width:100%;                         /* 弹性宽度 */margin-left:-200px                  /* 左侧外边距,负值向左缩进 */}div#content {                           /* 主栏内框 */margin-left:200px                   /* 左侧外边距,正值填充缩进 */}div#navigation {                        /* 导航栏 */float:right;                        /* 向右浮动 */width:200px                         /* 固定宽度 */}div#extra {                             /* 其他栏 */float:right;                        /* 向右浮动 */clear:right;                        /* 清除右侧浮动,避免同行显示 */width:200px                         /* 固定宽度 */}div#footer {                            /* 页眉区域 */clear:both;                         /* 清除两侧浮动,强迫外框撑起 */width:100%                          /* 宽度 */}

在这里插入图片描述
补充文本内容后的效果:
在这里插入图片描述

4.2、设计两栏弹性页面

在两栏浮动版式中,如果设置两列宽度都为自适应,那么设置起来会容易得多。例如,定义两栏版式中主栏向左浮动,宽度为70%,导航栏向右浮动,宽度为29.9%。

    div#wrapper {float:left;                              /* 向左浮动 */width:70%                                /* 百分比宽度 */}div#navigation {float:right;                             /* 向右浮动 */width:29.9%                              /* 百分比宽度 */}div#extra {clear:both;                              /* 清除左右浮动 */width:100%                               /* 满屏显示 */}

本案例版式设置导航栏与其他栏目并为一列固定在右侧,主栏目以弹性方式显示在左侧,实现主栏自适应页面宽度变化,而侧栏宽度固定不变的版式效果,如下图所示:
在这里插入图片描述
设计的方法是采用负外边距进行调节,核心样式如下所示:

    div#wrapper {                  /* 主栏外框 */float:right;               /* 向右浮动 */width:100%;                /* 弹性宽度 */margin-right:-33%;         /* 右侧外边距,负值向右缩进 */}div#content {                  /* 主栏内框 */margin-right:33%;          /* 右侧外边距,正值填充缩进 */}div#navigation {               /* 导航栏 */float:left;                /* 向右浮动 */width:32.9%;               /* 固定宽度 */}div#extra {                    /* 其他栏 */float:left;                /* 向左浮动 */clear:left;                /* 清除左侧浮动,避免同行显示 */width:32.9%                /* 固定宽度 */}div#footer {                   /* 页眉区域 */clear:both;                /* 清除两侧浮动,强迫外框撑起 */width:100%                 /* 宽度 */}

为了避免在IE7或者其他标准浏览器窗口中出现y轴滚动条,此时可以为body元素增加overflow-x:hidden;声明隐藏该滚动条:

    body { overflow-x:hidden;}

在这里插入图片描述

4.3、设计三栏弹性页面

本案例通过浮动布局的方法,以百分比为单位设置栏目的宽度,版式结构示意图如下图所示:
在这里插入图片描述
本案例采用负外边距的方法进行设计,这里设计三列都向左浮动,然后通过负外边距定位每列的显示位置,布局示意图如下图所示:
在这里插入图片描述
注意,其他栏目在不受外界干扰的情况下会浮动在导航栏的右侧,但是并列浮动的总宽度超出窗口宽度就会发生错位现象。如果没有受负外边距的影响,则会显示在第2行的位置,通过外边距取负值,强迫它们显示在主栏区域的上面。核心样式如下所示:

    div#wrapper {                   /* 主栏外包含框基本样式 */float:left;                 /* 向左浮动 */width:100%                  /* 百分比宽度 */}div#content {                   /* 主栏内包含框基本样式 */margin: 0 25%               /* 在左右两侧预留侧栏空间 */}div#navigation {                /* 导航栏基本样式 */float:left;                 /* 向左浮动 */width:25%;                  /* 百分比宽度 */margin-left:-100%           /* 左外边距取负值进行定位 */}div#extra {                     /* 其他栏基本样式 */float:left;                 /* 向左浮动 */width:25%;                  /* 百分比宽度 */margin-left:-25%            /* 左外边距取负值进行定位 */}div#footer {                    /* 页脚包含框样式 */clear:left;                 /* 清除左右浮动 */width:100%                  /* 百分比宽度 */}

三列弹性布局的版式设计效果如下图所示:
在这里插入图片描述

4.4、设计两栏固宽+弹性页面

单纯的弹性或者固定版式布局相对来说都比较好控制,但是如果要设计一列弹性、两列固定的版式就比较麻烦。不过灵活使用负外边距在网页布局中的技巧,可以解决类似复杂的布局。

本案例网页结构继续沿用上一节的模板示例结构。通过浮动布局的方法,以百分比和像素为单位来设置栏目的宽度,版式结构示意图如下图所示:
在这里插入图片描述
要定义导航栏和其他栏的宽度固定,不妨选用像素为单位,对于主栏可以采用百分比为单位,然后通过负外边距定位每列的显示位置。布局示意图如下图所示:
在这里插入图片描述
注意,其他栏目在不受外界干扰的情况下会浮动在导航栏的右侧,但是并列浮动的总宽度超出窗口宽度就会发生错位现象。如果没有受负外边距的影响,则会显示在第2行的位置,通过外边距取负值,强迫它们显示在主栏区域的上面。核心样式如下所示:

    div#wrapper {                    /* 主栏外包含框基本样式 */float:left;                  /* 向左浮动 */width:100%                   /* 百分比宽度 */}div#content {                    /* 主栏内包含框基本样式 */margin: 0 200px              /* 在左右两侧预留侧栏空间 */}div#navigation {                 /* 导航栏基本样式 */float:left;                  /* 向左浮动 */width:200px;                 /* 固定宽度 */margin-left:-100%            /* 左外边距取负值进行定位 */}div#extra {                      /* 其他栏基本样式 */float:left;                  /* 向左浮动 */width:200px;                 /* 固定宽度 */margin-left:-200px           /* 左外边距取负值进行定位 */}

一列弹性、两列固定版式的布局效果如下图所示:
在这里插入图片描述

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

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

相关文章

回归预测 | Matlab实现POA-CNN-SVM鹈鹕算法优化卷积神经网络-支持向量机多变量回归预测

Matlab实现POA-CNN-SVM鹈鹕算法优化卷积神经网络-支持向量机多变量回归预测 目录 Matlab实现POA-CNN-SVM鹈鹕算法优化卷积神经网络-支持向量机多变量回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.POS-CNN-SVM鹈鹕算法优化卷积神经网络-支持向量机的多变量回归…

将有序数组转换为二叉搜索树

做这一题的前提是要搞懂一些概念&#xff0c;比如什么是高度平衡的二叉树&#xff1f;什么又是搜索树&#xff1f; 二叉搜索树&#xff08;Binary Search Tree&#xff09; 它或者是一棵空树&#xff0c;或者是具有下列性质的二叉树&#xff1a; 若它的左子树不空&#xff0c;则…

CV计算机视觉每日开源代码Paper with code速览-2023.10.31

精华置顶 墙裂推荐&#xff01;小白如何1个月系统学习CV核心知识&#xff1a;链接 点击CV计算机视觉&#xff0c;关注更多CV干货 论文已打包&#xff0c;点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构】&#xff08;NeurIPS2023&#xff09;Fa…

EVM6678L 开发教程: IBL-TFTP 引导 elf 文件

目录 EVM6678L 开发教程: IBL-TFTP 引导 elf 文件安装 Tftpd64测试工程测试说明 EVM6678L 开发教程: IBL-TFTP 引导 elf 文件 参考: "C:\ti\mcsdk_2_01_02_06\tools\boot_loader\examples\i2c\tftp\docs\README.txt" 此教程介绍如何在 EVM6678L 开发板上实现 IBL-…

uni-starter 使用常见问题

1. Invalid uni-id config file 没有找到uni-id文件导致 需要在uniCloud-aliyun/cloudfunctions/common/uni-config-center/uni-id/下新建 config.json 如果没有uni-id 就新建一个。 注意&#xff1a;config.json是一个标准json文件&#xff0c;不支持注释 uni-starter 按照…

树形结构数据展示及返回上一级

11月1日&#xff0c;又是搬砖的一天&#xff0c;让我们红尘作伴&#xff0c;活的潇潇洒洒。。。。。。 html <template><view class"content"><view><input class"sreachTool" v-model"toolValue"/><van-icon name…

进口跨境电商商城源码(海关179接口+海关报关+三单对碰)

海关179接口 现如今&#xff0c;跨境电商正在飞速发展&#xff0c;进口商品成为人们消费的热点。然而&#xff0c;进口商品的报关手续繁琐&#xff0c;而海关179接口的出现解决了这个问题。海关179接口是指与海关电子数据交换的商业接口&#xff0c;可以实现与海关进行数据对接…

【生物信息学】单细胞RNA测序数据分析:计算亲和力矩阵(基于距离、皮尔逊相关系数)及绘制热图(Heatmap)

文章目录 一、实验介绍二、实验环境1. 配置虚拟环境2. 库版本介绍 三、实验内容0. 导入必要的库1. 读取数据集2. 质量控制&#xff08;可选&#xff09;3. 基于距离的亲和力矩阵4. 绘制基因表达的Heatmap5. 基于皮尔逊相关系数的亲和力矩阵6. 代码整合 一、实验介绍 计算亲和力…

【自然语言处理】【长文本处理】RMT:能处理长度超过一百万token的Transformer

相关博客 【自然语言处理】【长文本处理】RMT&#xff1a;能处理长度超过一百万token的Transformer 【自然语言处理】【大模型】MPT模型结构源码解析(单机版) 【自然语言处理】【大模型】ChatGLM-6B模型结构代码解析(单机版) 【自然语言处理】【大模型】BLOOM模型结构源码解析(…

【STL】:list用法详解

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下有关list的使用&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通 数据结构…

教您如何去除照片上的水印!

许多网友都在寻找方法去除照片上的水印&#xff0c;水印通常用于保护版权或标识来源&#xff0c;但有时候我们可能需要使用带有水印的照片&#xff0c;却又不希望水印影响观感&#xff0c;今天我将向大家介绍两种有效的方法&#xff0c;帮助解决“如何去除照片上的水印”这一难…

metaRTC集成flutter ui demo编译指南

概要 Flutter是由Google开发的开源UI工具包&#xff0c;用于构建跨平台应用程序&#xff0c;支持linux/windows/mac/android/ios等操作系统。 metaRTC新增flutter demo&#xff0c;支持linux/windows/mac/android/ios操作系统&#xff0c;此demo在ubuntu桌面环境下测试成功。…

【嵌入式项目应用】__UART自定义通信协议代码实现方法

目录 前言 一、什么是通信协议 二、简单通信协议的问题 三、通信协议的常见内容 1. 帧头 2. 设备地址/类型 3. 命令/指令 4. 命令类型/功能码 5. 数据长度 6. 数据 7.帧尾 8.校验码 四、通信协议代码实现 1. 消息数据发送 a. 通过串口直接发送每一个字节 b. 通过…

<windows>win11输入法无法设置UI,变为了win10样子,解决方法

1 问题 升级win11版本后&#xff0c;输入法可能会变为旧版&#xff0c;如下图。如何恢复WIN11新版样子&#xff1f; 2 解决 点击开始–>设置–>搜索”语言“–>选择中文简体右侧语言选项。 下拉到最后选择微软拼音右侧三点&#xff0c;选择键盘选项–>选择常规…

【C语言初阶】之函数

【C语言初阶】之函数 1. 函数是什么2. C语言中的函数2.1 库函数2.2.1 利用文档学习库函数 2.2 自定义函数 3. 函数参数3.1 实际参数(实参)3.2 形式参数(形参) 4. 函数调用4.1 传值调用4.2 传址调用4.3 练习 5. 函数的嵌套调用和链式访问5.1 嵌套调用5.2 链式访问 6. 函数的声明…

微服务架构之路1,服务如何拆分?使用微服务的注意事项?

目录 一、前言二、单体服务的弊端三、微服务化四、服务如何拆分&#xff1f;五、使用微服务的注意事项1、服务如何定义2、服务如何发布和订阅3、服务如何监控4、服务如何治理5、故障如何定位 大家好&#xff0c;我是哪吒。 一、前言 微服务已经是Java开发的必备技能&#xff…

Python画图之动态爱心

Python画出动态爱心&#xff08;有趣小游戏&#xff09; 一、效果图二、Python代码 一、效果图 二、Python代码 import random from math import sin, cos, pi, log from tkinter import *CANVAS_WIDTH 640 # 画布的宽 CANVAS_HEIGHT 480 # 画布的高 CANVAS_CENTER_X CANV…

线段树 区间赋值 + 区间加减 + 求区间最值

线段树好题&#xff1a;P1253 扶苏的问题 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 区间赋值 区间加减 求区间最大。 对于区间赋值和区间加减来说&#xff0c;需要两个懒标记&#xff0c;一个表示赋值cover&#xff0c;一个表示加减add。 区间赋值的优先级大于区间加…

大麦协议开发

1. 用户抢购请求处理&#xff1a; - 后端实现&#xff1a;在后端&#xff0c;您可以创建一个用于处理用户抢购请求的接口。当用户发起抢购请求时&#xff0c;后端会根据一定的算法和逻辑来处理请求。例如&#xff0c;可以使用分布式锁来保证只有一个用户能够成功抢购。示例后端…

VS2017制作安装包如何将整个文件夹添加进依赖项中

找到安装项目右键view-文件系统 找到Application Folder 右键Add-Folder 如Python38 选中创建的 Python38 在右侧的空白处粘贴要复制的文件即可。文件多&#xff0c;等待时间较长