css线条伸缩_CSS3弹性伸缩布局之box布局

CSS3弹性伸缩布局简介

2009年,W3C提出了一种崭新的方案----Flex布局(即弹性伸缩布局),它可以简便、完整、响应式地实现各种页面布局,包括一直让人很头疼的垂直水平居中也变得很简单地就迎刃而解了。但是这个布局方式还处于W3C的草案阶段,并且它还分为旧版本、新版本以及混合过渡版本三种不同的编码方式。其中混合过渡版本主要是针对IE10做了兼容。目前flex布局用得比较多的还是在移动端的布局,所以本次主要讲解一下旧版本和新版本在移动端使用的各个知识点,让大家对神秘的flex布局熟悉起来。

旧版本(box)

首先看一下浏览器兼容情况:

PS:浏览器兼容数据不一定很准确,不过相差不大。

下面将通过一个简单的实例来讲解旧版本的各个属性:

html代码:

XML/HTML Code复制内容到剪贴板

发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划哈萨空给

发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划哈萨

发生过的空间还是看价格哈健康啊水果和卡刷卡更何况规划

可以看到我们这个例子是很简单的,一个div元素内包含三个p元素,它们都是块元素(block)。接下来给段落加一些基础的样式:

CSS Code复制内容到剪贴板

p{

width:150px;

border:3pxsolidlightblue;

background:lightgreen;

padding:5px;

margin:5px;

}

此时刷新网页看到的结果是这样的:

这个结果很正常吧!OK,现在我们给div元素设置为box,看看有什么变化:

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

}

我们再次刷新网页,结果是这样的:

看到了吧,现在每一个p元素都变成一个box了,这就是弹性布局的神奇所在!

在上面中,我们将div元素的display设置为box,这就是旧版本的弹性布局。对于比较旧的浏览器版本,我们需要加上-webkit-前缀。

旧版本的弹性布局有两个属性值:

box : 将容器盒模型作为块级弹性伸缩盒显示 inline-box : 将容器盒模型作为内联级弹性伸缩盒显示

PS:我们知道块级它是占用整行的,比如div元素;而内联级不占用整行,比如span元素。但是我们设置了整个盒子,他们都不占用,保持一致。就像我们上面的例子一样,给div元素设置了盒子,那么div元素里面的p元素就不占用了。

下面介绍旧版本弹性布局的各个属性:

box-orient 属性

box-orient属性主要实现盒子内部元素的流动方向。

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-orient:vertical;

box-orient:vertical;

}

此时的结果就是垂直排列:

此属性的属性值有:

horizontal : 伸缩项目从左到右水平排列 vertical : 伸缩项目从上到下垂直排列inline-axis : 伸缩项目沿着内联轴排列显示block-axis : 伸缩项目沿着块轴排列显示

大家不妨试一下:horizontal 和 inline-axis 都是水平排列,而vertical 和 block-axis 都是垂直排列。

box-direction属性

box-direction 属性主要是设置伸缩容器中的流动顺序。

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-direction:reverse;

box-direction:reverse;

}

这样我们的排序就是反序的了,运行结果为:

此属性的属性值有:

normal : 正常顺序,默认值 reverse : 反序

box-pack属性

box-pack 属性用于伸缩项目的分布方式。

此属性的属性值有:

start : 伸缩项目以起始点靠齐 end : 伸缩项目以结束点靠齐 center : 伸缩项目以中心点靠齐 justify : 伸缩项目平局分布

下面我们都试一下各个属性值的效果:

1.start属性值

XML/HTML Code复制内容到剪贴板

div{

-webkit-box-pack:start;

box-pack:start;

}

这个就是默认靠齐方式:

2.end属性值

XML/HTML Code复制内容到剪贴板

div{

-webkit-box-pack:

end

;

box-pack:

end

;

}

这个就是以结束点靠齐:

3.center属性值

XML/HTML Code复制内容到剪贴板

div{

-webkit-box-pack:

center

;

box-pack:

center

;

}

这就是居中对齐效果:

4.justify属性值

XML/HTML Code复制内容到剪贴板

div{

-webkit-box-pack:

justify

;

box-pack:

justify

;

}

这个就是平均分布效果:

PS:垂直方向上也是一样的原理,但如果height为auto的话,效果将出不来。所以需要给height设置一个定高(最好比默认情况高)。这时,就能看到在垂直方向上的效果了。这里我就不再赘述了。

box-align属性

box-align 属性用来处理伸缩容器的额外空间。

此属性的属性值有:

start : 伸缩项目以顶部为基准,清理下部额外空间 end : 伸缩项目以底部为基准,清理上部额外空间 center : 伸缩项目以中部为基准,平均清理上下部额外空间baseline : 伸缩项目以基线为基准,清理额外的空间stretch : 伸缩项目填充整个容器,默认值

同样的,我们将试一下每个属性值的效果:

1.start属性值

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-align:start;

box-align:start;

}

效果如下:

2.end属性值

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-align:

end

;

box-align:

end

;

}

效果如下:

3.center属性值

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-align:

center

;

box-align:

center

;

}

效果如下:

4.baseline属性值

如果box-orient是内嵌单轴或横向,所有的子元素都置于他们的基线对齐。

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-orient:horizontal;

box-orient:horizontal;

-webkit-box-align:baseline;

box-align:baseline;

}

效果如下:

而如果box-orient是块轴或者垂直方向的,那么所有的子元素都将居中垂直排列。

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-orient:

vertical

;

box-orient:vertical;

-webkit-box-align:baseline;

box-align:baseline;

}

效果如下:

5.stretch属性值

所有子元素拉伸以填充包含区块。

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

-webkit-box-align:

stretch

;

box-align:

stretch

;

}

效果如下:

box-flex属性

box-flex 属性可以使用浮点数分配伸缩项目的比例。此属性是给容器内的项目设置的,它们会基于父容器的宽度来分配它们所占的比例:

XML/HTML Code复制内容到剪贴板

p:nth-child(1){

-webkit-box-flex:1;

box-flex:1;

}

p:nth-child(2){

-webkit-box-flex:3;

box-flex:3;

}

p:nth-child(3){

-webkit-box-flex:1;

box-flex:1;

}

效果如下:

当然也可以有些项目是固定宽度的,那么其他的项目也会分配剩余的宽度,比如这里第一个p元素设置为固定宽度:

XML/HTML Code复制内容到剪贴板

p:nth-child(2){

-webkit-box-flex:2;

box-flex:2;

}

p:nth-child(3){

-webkit-box-flex:1;

box-flex:1;

}

效果如下:

更多使用情况,大家可以自己慢慢去尝试。

box-ordinal-group 属性

box-ordinal-group 属性可以设置伸缩项目的显示位置。

XML/HTML Code复制内容到剪贴板

p:nth-child(1){

-webkit-box-ordinal-group:2;

box-ordinal-group:2;

}

p:nth-child(2){

-webkit-box-ordinal-group:3;

box-ordinal-group:3;

}

p:nth-child(3){

-webkit-box-ordinal-group:1;

box-ordinal-group:1;

}

效果如下:

可以看到:第一个p元素排在了第二,第二个p元素排在了第三,第三个p元素排在了第一。可以单独给某一个p元素设置此属性,其他项目会按照原来的顺序做变动。

OK,那么旧版本的所有属性就简单的介绍完了,更多结合的用法还是根据需要自己多动手去练习一下。

这里举一个水平垂直居中的例子:

XML/HTML Code复制内容到剪贴板

div{

display:-webkit-box;

display:box;

height:500px;

border:1px solid #f00;

-webkit-box-pack:center;

box-pack:center;

-webkit-box-align:center;

box-align:center;

}

那么效果就是这样的了:

此时我们再给p元素设置一个固定的高度:

XML/HTML Code复制内容到剪贴板

p{

width:150px;

height:200px;

}

那么这时的效果就是:

是不是很轻松就实现了这种效果呢!

小结

好的,到这里旧版本的弹性布局基础知识点就都介绍了一下。由于篇幅过长,怕大家看着疲劳,新版本的弹性布局(flex)我将放在下一篇介绍。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

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

相关文章

Android代码安装apk程序

文章目录一、高低版本兼容代码及配置1.java代码2.AndroidManifest.xml 配置ContentProvider3.paths xml 配置二、老版本代码三、可能出的问题及处理一、高低版本兼容代码及配置 高版本提高了sdcard、 app文件空间的访问权限,高低版本的系统api有一定区别&#xff0…

Android adb 安装apk程序

文章目录ADB简单介绍安装命令安装失败情况adb 安装测试包adb 安装卸载的所有命令摘要前言多数情况下,用户都是从应用商店或某网页下载apk后从手机上直接安装apk文件,在调试或下载到电脑上时候,我们就可以直接通过adb安装到手机。在测试小伙伴…

XML十六进制无效的字符(0x0b 0x0c 0x02)

文章目录解决方法ASCII“字符”1、ASCII 打印字符2、ASCII 非打印控制字符3、扩展 ASCII 打印字符4、ASCII 之外ASCII 字符输入方法与常用地方1、在文档中插入 ASCII 字符2、输入方法前言xml 中包含了非打印字符的情况下,即使是放在cdata 中,在不同平台上…

tab栏圆点按钮_uniapp tabbar上的小圆点

需求在tabbar的图标右侧显示和隐藏小圆点。一般表示有新消息、新更新。基本代码序号从0开始计算。uni.showTabBarRedDot({index:1});uni.hideTabBarRedDot({index:1});修改代码App.vue或index页在App.vue的onLaunch周期或者是index页的onLoad加入代码,判定是否需要显…

Android OpenGLES2.0(一)OpenGLES2.0基础介绍

文章目录什么是OpenGL ES?OpenGL ES可以做什么?OpenGL ES版本及Android支持情况OpenGL ES 2.0的优点OpenGL ES 2.0中基本概念顶点着色器片元着色器着色器语言坐标系图形的绘制投影光照纹理映射其它OpenGL ES 2.0过程及理解什么是OpenGL ES? O…

如何 方法内指令重排 进制_谈谈指令重排

这个知识点也是很多人说不清道不明的地方,感觉都知道,说又说不出来。为什么会这样呢?因为这几个字,很容易被当成动词去理解,其实正确的理解是当成名词,即指令重排现象。那什么时候会产生指令重排现象呢&…

Windows ‘ls‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件

文章目录前言原因解决办法前言 Windows和mac混用或Windows与linux混用的情况下,在windows dos窗口随手一个ls,出现了 ‘ls’ 不是内部或外部命令,也不是可运行的程序 或批处理文件。 原因 ls是linux的命令,不是windows的命令,win…

python问题解决了吗_Python 问题怎么解决?

展开全部主要问题和解决方法如下:中文路径的问题:在D盘下保32313133353236313431303231363533e58685e5aeb931333365633939存一个名字为‘中文.txt‘的文件。运行如下测试代码:# -*- coding: utf-8 -*-fopen(D:\\中文.txt, r)print f.read()&a…

Linux ls 命令使用介绍

文章目录命令格式命令功能常用参数常用示例示例1 列出文件夹下的所有文件和目录的详细资料示例2 列出当前目录中所有以“t”开头的目录的详细内容,示例3 只列出文件下的子目录命令:示例4 列出目前工作目录下所有名称是以s开头的档案,越新的排…

exls导入数据库 php_PHP读取excel文件并导入数据库

PHPExcel是一个PHP类库,用来帮助我们简单、高效实现从Excel读取Excel的数据和导出数据到Excel。下面是PHPExcel读取的使用教程:1.首先下载PHPExcel2.下载好文件,解压可以得到如下文件:为了使用方便,我们可以在根目录创…

Linux cd 命令使用介绍

文章目录1. 命令格式2. 命令功能3. 常用范例示例1:进入系统根目录cd /2:使用 cd 命令进入当前用户主目录3:跳转到指定目录4:返回进入此目录之前所在的目录5:把上个命令的参数作为cd参数Linux cd 命令是Linux中最基本的…

netty冲突 play sbt_《Netty官方文档》本地传输接口

原文链接 译者:gm777自4.016版本以来, Netty提供了本地的socket传输使Linux系统可以使用JNI(JAVA本地接口)。这个传输接口不仅有着高性能并且产生更少的垃圾,所以你也许会想尝试使用一下。使用本地传输接口由于这个本地传输接口是与NIO传输接…

Linux pwd 命令使用介绍

文章目录1.命令格式2.命令功能3.常用参数4.常用实例实例1:用 pwd 命令查看默认工作目录的完整路径实例2:使用 pwd 命令查看指定文件夹Linux中用 pwd 命令来查看”当前工作目录“的完整路径。每当我们在终端…

java参数传入泛型类型_Java泛型参数界定到任何一个类型的范围

是否有一种语法或解决方法来将泛型类型参数限制为任何一种类型的类型?我知道您可以将类型限制为所有类型的所有类型(即AND逻辑):public class MyClass & Serializable> { } // legal syntax有OR逻辑版本,就是这样的:public class MyCl…

Linux mkdir 命令使用介绍

文章目录1.命令格式2.命令功能3.命令参数4.命令实例实例1:创建一个空目录实例2:递归创建多个目录或一次创建多级目录实例3:创建权限为777的目录实例4:创建新目录都显示信息实例5&…

jmeter修改redis_jmeter如何访问redis服务缓存

Redis(REmote DIctionary Server)是一个开源的内存数据结构存储,用作数据库,缓存和消息代理。作为内存数据库,它将所有数据保存在RAM中。Redis在读取/写入数据时实现高性能,并且在您需要确保在所有测试服务器上使用唯一数据时也很…

Linux rm/rmdir 命令使用介绍

文章目录1.命令格式2.命令功能3.命令参数4.命令实例1. 删除文件,系统会先询问是否删除。2. 强行删除文件,系统不再提示3. 删除任何.txt文件;删除前逐一询问确认4. 将目录及子目录中所有档案删除…

window服务器cpu过高的排查_线上服务器发生CPU占用率过高应该如何排查并定位问题?...

国外开发者平台 HankerRank 发布的 2018 年开发者技能调查报告中有一项关于"雇主最看重哪些核心能力"的调查,结果显示如下:排名前几的比较受重视的能力分别为:解决问题、编程语言熟练程度、Debug、系统设计和性能优化。解决问题的能…

Linux mv 命令使用介绍

文章目录1.命令格式2.命令功能3.命令参数4.命令实例1、文件改名( 重命名)2、移动文件3、将test目录下的文件text1.txt text2.txt text3.txt移动到目录mv中。4、将文件file1改名为file2,如果file…

Linux touch 命令使用介绍

文章目录1.命令格式2.命令参数3.命令功能4.使用范例1、创建不存在的文件,用法如下2、更新text.txt 的时间和text3.txt时间戳相同3、设定文件的时间戳-t time 格式详细说明linux中的touch命令一般用来修改文件时间戳&am…