详解CSS从条纹边框的实现盒子模型的方法

高洛峰
Lepaskan: 2017-03-24 09:53:52
asal
1227 orang telah melayarinya

解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 CSS属性,赶紧去补习一下吧。

2、类似下面这个图形,只使用一个标签,可以有多少种实现方式:

详解CSS从条纹边框的实现盒子模型的方法

假设我们的单标签为p:

Salin selepas log masuk

定义如下通用 CSS:

p{ position:relative; width: 180px; height: 180px; }
Salin selepas log masuk

这一题主要考查的是盒子模型Box Model与 背景background的关系,以及使用background-clip改变背景的填充方式。

backgroundBox Model中,他是布满整个元素的盒子区域的,并不是从padding内部开始(也就是说从 border 就开始啦),只不过实线边框(solid)部分遮住了部分background,所以我们使用虚线边框(dashed)就可以看到背景色是从border内部开始的。

我们给p添加如下样式:

p{ background:#9c27b0; border:20px dashed #2196f3; }
Salin selepas log masuk

结果如下:
详解CSS从条纹边框的实现盒子模型的方法

但有一点需要注意,background-color是从元素的边框左上角起到右下角止,而background-image却不一样,他是从padding边缘的左上角起而到border的右下角边缘止。

background image 的绘制中有两个因素决定了绘图区域:

  • background positioning area。background-origin属性决定了这个相对定位位置,默认为padding-box。所以默认的背景图片绘制是从 padding box 的左上顶点开始的。

  • background painting area。background-clip属性决定了绘制区间,默认为border-box。所以在background-repeat: repeat的情况下:

The image is repeated in thisdirectionas often as needed to cover the background painting area.

嗯,什么意思呢,你可以戳进这个 demo 看看,正常情况下的背景图填充如下:

详解CSS从条纹边框的实现盒子模型的方法

当然,这个填充规则是可以通过background-clip改变的。

background-clip设置元素的背景(背景图片或颜色)是否延伸到边框下面。

语法:

{ background-clip: border-box; // 背景延伸到边框外沿(但是在边框之下) background-clip: padding-box; // 边框下面没有背景,即背景延伸到内边距外沿。 background-clip: content-box; // 背景裁剪到内容区 (content-box) 外沿。 }
Salin selepas log masuk

继续说回本题,接下来,只需要将中间部分填充为白色即可,这个用伪元素可以轻松完成,所以,其中一个方法如下:

p{ background:#9c27b0; border:20px dashed #2196f3; } p::after{ content:""; position:absolute; top:0; left:0; bottom:0; right:0; background:#fff; }
Salin selepas log masuk

法二:

上面的方法,我们使用了p的背景色默认情况下从border开始填充,及伪元素设置白色背景色填充p的中间的padding-box区域完成图形。

也可以反过来,使用伪元素背景色从border-box开始填充,使用p的背景色填充中间padding-box区域。

p{ background:#fff; background-clip:padding-box; border:20px dashed #cccc99; } p::before{ content:""; position:absolute; top:-20px; left:-20px; bottom:-20px; right:-20px; background:#996699; z-index:-1; }
Salin selepas log masuk

上面法二除了用到了background-clip改变背景的填充区域,还用到了z-index触发元素生成了堆叠上下文(stacking context),改变了元素的层叠顺序(stacking levle),让伪元素背景色叠到了p 背景色之下,这两个概念下题会提及。

法....

本题主要是想讨论一下 CSS 的盒子模型Box Model与 背景background的关系,其实本题就是在于一个 dashed 边框,内部使用颜色填充即可,与上面第一题异曲同工,使用阴影、渐变都可以完成,感兴趣可以自己尝试一下其他解法。


Atas ialah kandungan terperinci 详解CSS从条纹边框的实现盒子模型的方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!