惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Stack Overflow Blog
Stack Overflow Blog
WordPress大学
WordPress大学
罗磊的独立博客
S
Secure Thoughts
Schneier on Security
Schneier on Security
博客园 - Franky
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
爱范儿
爱范儿
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Hacker News: Ask HN
Hacker News: Ask HN
PCI Perspectives
PCI Perspectives
Google DeepMind News
Google DeepMind News
S
Security Affairs
SecWiki News
SecWiki News
博客园 - 聂微东
Security Archives - TechRepublic
Security Archives - TechRepublic
Google Online Security Blog
Google Online Security Blog
H
Heimdal Security Blog
S
Security @ Cisco Blogs
Engineering at Meta
Engineering at Meta
C
CXSECURITY Database RSS Feed - CXSecurity.com
Cloudbric
Cloudbric
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
V
Visual Studio Blog
P
Proofpoint News Feed
Project Zero
Project Zero
T
Threat Research - Cisco Blogs
Webroot Blog
Webroot Blog
Blog — PlanetScale
Blog — PlanetScale
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
W
WeLiveSecurity
Last Week in AI
Last Week in AI
月光博客
月光博客
Microsoft Azure Blog
Microsoft Azure Blog
M
MIT News - Artificial intelligence
有赞技术团队
有赞技术团队
S
Securelist
GbyAI
GbyAI
Application and Cybersecurity Blog
Application and Cybersecurity Blog
C
CERT Recently Published Vulnerability Notes
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Cyberwarzone
Cyberwarzone
B
Blog RSS Feed
P
Palo Alto Networks Blog
H
Hacker News: Front Page
D
Docker
雷峰网
雷峰网
Latest news
Latest news
Microsoft Security Blog
Microsoft Security Blog

张鑫旭-鑫空间-鑫生活

1分钟速度了解text-align match-parent声明 « 张鑫旭-鑫空间-鑫生活 光标的形状也能设置了,就是CSS caret-shape属性 « 张鑫旭-鑫空间-鑫生活 pretext与文字四面环绕效果的实现 « 张鑫旭-鑫空间-鑫生活 JSON.rawJSON方法的作用是什么? « 张鑫旭-鑫空间-鑫生活 如何使用CSS判断鼠标从哪个方向进入元素? « 张鑫旭-鑫空间-鑫生活 借助mediabunny纯JS实现视频水印、剪裁、合成等功能 « 张鑫旭-鑫空间-鑫生活 务必谨慎使用JS WeakRef弱引用 « 张鑫旭-鑫空间-鑫生活 CSS六边形头像的实现与蜂巢布局 « 张鑫旭-鑫空间-鑫生活 CSS corner-shape与背景底纹技术 « 张鑫旭-鑫空间-鑫生活 浅学WebTransport API:下一代Web双向通信技术 « 张鑫旭-鑫空间-鑫生活 HTML dialog元素新支持了closedBy属性 « 张鑫旭-鑫空间-鑫生活 HTML interestfor属性与悬停popover交互效果 « 张鑫旭-鑫空间-鑫生活 CSS3模拟window7炫酷界面效果展示 « 张鑫旭-鑫空间-鑫生活 图片旋转+剪裁js插件(兼容各浏览器) « 张鑫旭-鑫空间-鑫生活 纯js无图片无外链CSS图片幻灯片播放插件 « 张鑫旭-鑫空间-鑫生活 CSS border三角、圆角图形生成技术简介 « 张鑫旭-鑫空间-鑫生活 CSS “渐进增强”在web制作中常见应用举例 « 张鑫旭-鑫空间-鑫生活 让IE6/IE7/IE8浏览器支持CSS3属性 « 张鑫旭-鑫空间-鑫生活 jQuery – 高亮动态显示页面HTML代码插件 « 张鑫旭-鑫空间-鑫生活 翻译 – 逐渐消失的Flash网站 « 张鑫旭-鑫空间-鑫生活 CSS reset的重新审视 – 避免样式重置 « 张鑫旭-鑫空间-鑫生活 新浪微博插入话题后部分文字选中的js实现 « 张鑫旭-鑫空间-鑫生活 JavaScript实现http地址自动检测并添加URL链接 « 张鑫旭-鑫空间-鑫生活 CSS实现兼容性的渐变背景(gradient)效果 « 张鑫旭-鑫空间-鑫生活 CSS content内容生成技术以及应用 « 张鑫旭-鑫空间-鑫生活 CSS gradient渐变之webkit核心浏览器下的使用 « 张鑫旭-鑫空间-鑫生活 CSS渐变之CSS3 gradient在Firefox3.6下的使用 « 张鑫旭-鑫空间-鑫生活 区分IE8/IE7/IE6及其他浏览器-CSS “\9″hack « 张鑫旭-鑫空间-鑫生活 CSS实现跨浏览器兼容性的盒阴影效果 « 张鑫旭-鑫空间-鑫生活 CSS3&HTML5各浏览器支持情况一览表 « 张鑫旭-鑫空间-鑫生活 翻译 – CSS Sprites:实用技术还是生厌之物? « 张鑫旭-鑫空间-鑫生活 纯CSS实现易拉罐3D滚动效果 « 张鑫旭-鑫空间-鑫生活 纯CSS实现侧边栏/分栏高度自动相等 « 张鑫旭-鑫空间-鑫生活 CSS+JavaScript实现页面不同布局的切换 « 张鑫旭-鑫空间-鑫生活 JavaScript实现最简单的拖拽效果 « 张鑫旭-鑫空间-鑫生活 自己写的无图片版jQuery zxxbox弹出框插件 « 张鑫旭-鑫空间-鑫生活 中国古代道家思想与网页重构的思考 « 张鑫旭-鑫空间-鑫生活 让所有浏览器支持HTML5 video视频标签 « 张鑫旭-鑫空间-鑫生活 纯CSS实现各类气球泡泡对话框效果 « 张鑫旭-鑫空间-鑫生活 JS HEX十六进制与RGB, HSL颜色的相互转换 « 张鑫旭-鑫空间-鑫生活 CSS实现兼容性的渐变、高光等文字效果 « 张鑫旭-鑫空间-鑫生活 去除冗余 – 精简您的CSS样式代码 « 张鑫旭-鑫空间-鑫生活 对overflow与zoom”清除浮动”的一些认识 « 张鑫旭-鑫空间-鑫生活 jQuery Pagination Ajax分页插件中文详解 « 张鑫旭-鑫空间-鑫生活 absolute绝对定位的非绝对定位用法 « 张鑫旭-鑫空间-鑫生活 网页布局思想浅议-淘宝新版首页为实例 « 张鑫旭-鑫空间-鑫生活 回流与重绘:CSS性能让JavaScript变慢? « 张鑫旭-鑫空间-鑫生活 CSS float浮动的深入研究、详解及拓展(二) « 张鑫旭-鑫空间-鑫生活 CSS float浮动的深入研究、详解及拓展(一) « 张鑫旭-鑫空间-鑫生活 60个极富创造性的震撼的电影海报设计 « 张鑫旭-鑫空间-鑫生活 jQuery Lightbox(balupton版)图片展示插件讲解 « 张鑫旭-鑫空间-鑫生活 博客内嵌flash音乐播放器代码、下载与使用 « 张鑫旭-鑫空间-鑫生活 CSS3 animate实现图片墙3D翻转效果 « 张鑫旭-鑫空间-鑫生活 图片旋转效果的一些研究、jQuery插件及实例 « 张鑫旭-鑫空间-鑫生活 CSS3 border-image详解、应用及jQuery插件 « 张鑫旭-鑫空间-鑫生活 jQuery-两款不同原理的圆角插件讲解 « 张鑫旭-鑫空间-鑫生活 页面可用性之outline轮廓外框的一些研究 « 张鑫旭-鑫空间-鑫生活 CSS3 transition实现超酷图片墙动画效果 « 张鑫旭-鑫空间-鑫生活 HTML CSS列表元素ul,ol,dl的研究与应用 « 张鑫旭-鑫空间-鑫生活 jQuery图片文本滚动切换插件jCarousel中文翻译与详解 « 张鑫旭-鑫空间-鑫生活 酷酷的jQuery鼠标悬停图片放大切换显示效果 « 张鑫旭-鑫空间-鑫生活 IE6下z-index犯癫不起作用bug的初步研究 « 张鑫旭-鑫空间-鑫生活 checkbox复选框的一些深入研究与理解 « 张鑫旭-鑫空间-鑫生活 jQuery之使用slideToggle实现垂直下拉菜单 « 张鑫旭-鑫空间-鑫生活 jQuery-innerfade内部列表自动淡入淡出插件 « 张鑫旭-鑫空间-鑫生活 jQuery-火焰灯效果导航菜单 « 张鑫旭-鑫空间-鑫生活 IE下css bug集合-翻译自haslayout.net « 张鑫旭-鑫空间-鑫生活 翻译-IE7/8@font-face嵌入字体与文字平滑 « 张鑫旭-鑫空间-鑫生活 jQuery-马化腾产品设计与用户体验的一些技术实现 « 张鑫旭-鑫空间-鑫生活 像素的世界及其在web开发制作中的应用 « 张鑫旭-鑫空间-鑫生活 css行高line-height的一些深入理解及应用 « 张鑫旭-鑫空间-鑫生活 CSS实现圆角六色渐变自适应按钮详解 « 张鑫旭-鑫空间-鑫生活 我熟知的三种三栏网页宽度自适应布局方法 « 张鑫旭-鑫空间-鑫生活 jQuery照片图像剪裁插件Jcrop中文翻译详解 « 张鑫旭-鑫空间-鑫生活 Ajax Upload多文件上传插件翻译及中文演示 « 张鑫旭-鑫空间-鑫生活 告别图片—使用字符实现兼容性的圆角尖角效果beta版 « 张鑫旭-鑫空间-鑫生活 大小不固定的图片、多行文字的水平垂直居中 « 张鑫旭-鑫空间-鑫生活 jQuery boxy弹出层对话框插件中文演示及讲解 « 张鑫旭-鑫空间-鑫生活 JavaScript实现新浪微博文字放大显示动画效果 « 张鑫旭-鑫空间-鑫生活 翻译:让网络更快一些——最小化浏览器中的回流(reflow) « 张鑫旭-鑫空间-鑫生活 jQuery之addClasas与removeClass使用实例 « 张鑫旭-鑫空间-鑫生活 关于Google圆角高光高宽自适应按钮及其拓展 « 张鑫旭-鑫空间-鑫生活 JavaScript实现图片幻灯片滚动播放动画效果 « 张鑫旭-鑫空间-鑫生活 jQuery-鼠标经过显示大图并跟随鼠标效果插件 « 张鑫旭-鑫空间-鑫生活 关于gif图片(或png8)杂边锯齿的问题 « 张鑫旭-鑫空间-鑫生活 对html与body的一些研究与理解 « 张鑫旭-鑫空间-鑫生活 鲜为人知的一个解决兼容性问题的利器——小数 « 张鑫旭-鑫空间-鑫生活 搜狐白社会似iphone短信对话框效果的优化 « 张鑫旭-鑫空间-鑫生活 关于文字内容溢出用点点点(…)省略号表示 « 张鑫旭-鑫空间-鑫生活 jquery之append与insertBefore使用实例 « 张鑫旭-鑫空间-鑫生活 jQuery之图片关联伸缩效果 « 张鑫旭-鑫空间-鑫生活 jquery之图片左右切换动画效果 « 张鑫旭-鑫空间-鑫生活 jQuery之replace字符串替换实现不同尺寸图片切换 « 张鑫旭-鑫空间-鑫生活 jQuery-实现图片的放大镜显示效果 « 张鑫旭-鑫空间-鑫生活 jQuery-单击文字或图片内容放大显示效果插件 « 张鑫旭-鑫空间-鑫生活 reflection.js-实现图片投影倒影效果js插件 « 张鑫旭-鑫空间-鑫生活 jQuery-很酷的弹出层效果js插件 « 张鑫旭-鑫空间-鑫生活 复选框单选框与文字对齐问题的研究与解决 « 张鑫旭-鑫空间-鑫生活 css margin的相关属性,问题及应用 « 张鑫旭-鑫空间-鑫生活 IE6下png背景不透明问题的综合拓展 « 张鑫旭-鑫空间-鑫生活
CSS grid-auto-flow深入理解 « 张鑫旭-鑫空间-鑫生活
张鑫旭,zhangxinxu · 2020-01-15 · via 张鑫旭-鑫空间-鑫生活

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=9200
本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。

考拉和树

一、grid-auto-flow出现的背景

Grid布局要想玩得666,grid-auto-flow是绕不开的需要深度掌握的CSS属性。

Grid布局就像农村土改分土地。

政府会把土地分成一块一块的,然后这一块是张三的,那一块是王二的。

这个划分就是通过grid-template属性。

比方说:

.fileds {
    display: grid;
    grid-template: 1fr 1fr / 1fr 1fr;
}

就是把这块土地分成两行,两列4块田地。

然而应用到具体的场景,事情往往就出乎意料的复杂。

例如:

  1. 如果日后村里搬迁了几户新住户,那该怎么划分?
  2. 4块田地分给张三和王二,你说是横的两块地给张三呢,还是竖的两块地给张三?
  3. 孤寡老人李大爷过世了,他的田地是否可以分给后面的人?

这些意料之外的场景单靠grid-template属性肯定捉襟见肘,此时,就需要grid-auto-flow属性出马。

grid-auto-flow属性可以定义Grid布局中每一个Grid子项“自动流动”状态。

更新于2020-05-25

这里提到的所谓的“意料之外的场景”与grid-auto-flow属性毛线关系都没有,其实是grid-auto-columnsgrid-auto-rows属性应该做的事情。

grid-auto-flow属性的地方更像是Flex布局中的flex-direction属性,是用来控制grid子项的流向的。

二、了解grid-auto-flow的语法

grid-auto-flow: [ row | column ] || dense

因此,下面这些写法都是合法的:

grid-auto-flow: row;
grid-auto-flow: column;
grid-auto-flow: dense;
grid-auto-flow: row dense;
grid-auto-flow: column dense;

其中:

row
多的格子一行一行陈列。默认值。
column
多的格子一列一列排列。
dense
多的格子空白填充。

各个关键字值具体什么意思,我们还得看案例才能明白。

三、row和column属性值基础

1. 默认值row

从天上掉下来一个宝贝容器,定睛一看,容器元素标签名是zxx-grid,好巧,正好应用的CSS声明就是display:grid,如下:

zxx-grid {
    display: grid;
}

然后很巧的是还有若干子元素,如下:

<zxx-grid>
    <zxx-item>格子1</zxx-item>
    <zxx-item>格子2</zxx-item>
    <zxx-item>格子3</zxx-item>
    <zxx-item>格子4</zxx-item>
    <zxx-item>格子5</zxx-item>
    <zxx-item>格子6</zxx-item>
    <zxx-item>格子7</zxx-item>
    <zxx-item>格子8</zxx-item>
    <zxx-item>格子9</zxx-item>
</zxx-grid>

<zxx-grid>元素除了应用了display:grid没有任何其他CSS,因此,所有的子元素的grid-auto-flow“自动流动”的状态是其默认值。

grid-auto-flow的默认值是rowrow的中文意思是“行”,也就是所有的子元素一行一行显示,优先水平排列。

于是,最终的网格轮廓结构会是下图这样:

格子全部都一行一行排列

更进一步

如果我们使用grid-template属性指定Grid的列数为2列,如下:

zxx-grid {
    display: grid;
    grid-template: auto / 1fr 1fr;
    line-height: 40px;
}

大家就会看到Grid子元素的排列流向是下面这样的,先是水平排列,然后再到下一行再水平排列,一直到最后不断循环:

auto-flow为row时候的格子流向

大家可能觉得理所当然就应该这样排列,太天真了!

太天真了 唐三

大家稍后对比column属性值的效果就知道Grid子项的排列顺序并不是一成不变的了。

2. 关键字值column

如果我们设置grid-auto-flow的属性值是columncolumn的中文意思是“列”,则表示“自动流动”状态的子元素全部都一列一列显示。

假设容器元素CSS如下:

zxx-grid {
    display: grid;
    grid-auto-flow: column;
}

则几个子元素的布局效果会是下面截图这样,全部纵排了:

布局纵排示意

发现没有?使用grid-auto-flow属性可以非常简单实现子元素个数不固定的等分布局效果,就是值设置为column就可以了。

更进一步

这里,我们同样指定我们的Grid布局是2行,CSS代码如下:

zxx-grid {
    display: grid;
    grid-template-rows: 1fr 1fr;
    grid-auto-flow: column;
    line-height: 40px;
}

大家就会发现Grid子元素的排列流向和row属性值就不一样了:

grid-auto-flow:column格子的流向

是优先垂直方向排列,然后再到下一列往下排列,一直循环往复到最后一列。

由此,我们可以得出结论,grid-auto-flow属性会影响Grid布局的排列顺序。

3. 排序与布局实例

有人在微信粉丝群里面问了下面这个问题,实现下图所示布局:

图片布局示意

这个布局效果,最简单的方法就是用浮动3个图片都设置float:left就可以了,就这么简单。

但是如果我们这里的图片不是3个,而是5个(如下图),那么浮动就无能为力了。

5个图片布局

此时,则可以试试Grid布局,让第一个子项横跨左侧两个格子,然后后面4个格子按照grid-auto-flow:column的流向排列即可。

HTML代码如下:

<zxx-grid>
    <zxx-item><img src="./xugou-1.jpg"></zxx-item>
    <zxx-item><img src="./xugou-2.jpg"></zxx-item>
    <zxx-item><img src="./xugou-3.jpg"></zxx-item>
    <zxx-item><img src="./xugou-4.jpg"></zxx-item>
    <zxx-item><img src="./xugou-5.jpg"></zxx-item>
</zxx-grid>

CSS代码如下:

zxx-grid {
    display: grid;
    grid-auto-flow: column;
    grid-template: 1fr 1fr / 1fr 1fr 1fr;
    grid-template-areas: "a b d" "a c e";
    grid-gap: 6px;
}
zxx-item:first-child {
    grid-area: a;    
}

则有如下图所示的布局效果:

排列布局效果

而且整个布局是弹性变化的,如下视频所示(不动可以点击播放):

对吧,布局效果还是很酷的。


最后,测试下grid-auto-flow:column在这个例子中所起的作用,我们打开控制台,注释掉grid-auto-flow:column这句CSS声明,则我们会得到下图所示的布局效果,图2到图5都是水平平铺呈现,这个效果Float浮动就可以实现。

column值的作用示意

对应的Demo页面

上面的例子有专门的demo演示页面,您可以狠狠的点击这里:grid布局实现图像A|B+C布局demo

//zxx: Chrome浏览器的图片height:100%似乎有bug,Firefox浏览器没有这个问题

四、row和column属性值深入

第三小节演示的几个案例都是我们所有的格子都已经规定好的,但是实际开发,Grid格子的数量可能是动态的,无论是grid-template还是grid-template-areas往往就没法兼顾全部的子元素,此时,Grid布局又该如何表现?

为了更进一步展示关键字值column的效果,我们来看一个稍微再复杂一点的例子:

我们设定网格模板是 2 x 2,也就是前4个元素按照指定网格陈列,后面的子元素auto-flow自由流动。相关CSS如下:

zxx-grid {
    display: grid;
    grid-template: 1fr 1fr / 1fr 1fr;
    grid-auto-flow: column;
}

则最终效果如下:

未定义网格的column排列示意

为什么会有上图这样的效果呢?

首先大家一定要搞清楚一点,1fr 1fr并不等于50% 50%,虽然很多时候表现是一样的,但只是grid格子正好和设定数量一致的时候。1fr 1fr更准确的含义是,可用剩余空间分别50% 50%

在本例中,格子5~格子9属于“放任自流”的盒子,因为grid-template:1fr 1fr / 1fr 1fr只指定了4个格子的尺寸,那剩余的5个格子怎么办呢?

那就是grid-auto-flow属性大发神威的时候。

这里grid-auto-flow设置的属性值是column,也就是没有指定模板的剩余5个格子垂直按需排列。如下图标注:

5个格子排列

由于没有指定宽度,因此,格子的尺寸就fit-content,根据内容的尺寸来。


在实际开发的时候,我们往往只要指定好垂直列的个数和宽度分配比,无论多少个grid子元素,都会依次排列好,其最底层最根本的原因其实是grid-auto-flow:row在起作用。

例如:

zxx-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

效果是下面这样,9个格子了,一个一个排的非常整齐,因为“自动流动”默认是水平的。

9个格子默认排列示意

五、不太好懂的dense属性值

最后,再讲讲dense属性值。

dense单从字面含义是不太好理解的,dense的中文意思是“密集的”,“稠密的”,“浓密的”。

密集的是树林,稠密的是奶昔,浓密的是头发,跟Grid布局好像不搭边吧。

实际上,这里dense应该用一种更感性的方式去体会这个词的含义。

在本文一开始提到了一个引子“孤寡老人李大爷过世了,他的田地是否可以分给后面的人?”

比如说村里9户人家,每一户都分得了一块田地,大家的田地都是紧密相连的。

结果孤寡老人李大爷和王大爷相继去世。于是,就有两块田地是空缺的,因为有空缺,所以这个时候,如果我们使用无人机从上方拍一个照片,则田地是稀疏的,不是紧密的。

这个时候,村里又来了两户新人家,也要分田地。

如果是dense,则优先分配之前李大爷和王大爷留下的空缺的土地,因为这样会让整片田地没有空缺,是“密集的”,“紧密的”。

grid-auto-flow:dense也是类似的意思。

dense理解案例

我们可以人为制造出稀疏布局结构(前面几个Grid格子留空),代码如下:

zxx-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
zxx-item:first-child {
    grid-column-start: 2;
}

效果如下,第一个格子空缺了:

grid布局-前面留空

如果我们希望第一个格子被充分利用,让整个排列是紧密相连的,则可以使用dense关键字值。

zxx-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-flow: dense;
}
zxx-item:first-child {
    grid-column-start: 2;
}

此时浏览器的渲染表现是怎样的呢?请看下图:

格子2渲染上去了

原本流出来的第1个格子的窟窿,被格子2给填上了。

这个Grid布局又是“紧密的”了,这就是dense属性的作用。

dense实际开发的时候有什么作用呢?

比方说我希望某两个相邻的格子视觉顺序和DOM顺序是相反的,也就是两者调换位置,则可以使用dense实现。

其他

dense可以和row以及column这两个关键字只是同时使用,例如:

grid-auto-flow: row dense;  // 等同于dense
grid-auto-flow: column dense;

六、最后的总结么么哒

本文虽然只有5000字,不过花的时间还挺多,算上今天,断断续续写了一周。

一周记录

为什么这篇文章跨度时间比较长呢?除了用心做demo,用心创作外,还有其他两方面主要原因:

  1. 边研究边测试边写,结果发现了自己一开始想当然的错误理解,然后不少内容重新组织推翻重来。因此可见,写文章其实对深度学习、了解细节,理清思路非常有帮助,是非常好的一种学习方法。
  2. 现在上年纪了,体力没以前好了。以前都是写到1点,这种程度的文章2~3天就完成。现在顶不住了,12点左右就困得不行,关机睡觉去了,所以写作时间跨度就更长了。

CSS文章已经连更十几篇了,小本本上还有好几篇CSS文章要写的。

光CSS基础API只是更新迭代的东西就这么多,再考虑到吃了激素一路狂奔年年暴走的ES规范,现在的前端开发想成为通才基本上不可能了,只能选择合适的领域,一点一点发光发热吧。

哎呀呀,就说这么多了。

用心之作,欢迎分享!

行文匆忙,如果文章有表述不准确的地方,欢迎指正!

本文为原创文章,欢迎分享,勿全文转载,如果实在喜欢,可收藏,永不过期,且会及时更新知识点及修正错误,阅读体验也更好。
本文地址:https://www.zhangxinxu.com/wordpress/?p=9200

(本篇完)