CSS/CSS3 box-decoration-break属性图文简介

栏目: CSS · 发布时间: 5年前

内容简介:byzhangxinxu from本文可全文转载,个人网站无需授权,只要保留原作者、出处以及文中链接即可,任何网站均可摘要聚合,商用请联系授权。

byzhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8346

本文可全文转载,个人网站无需授权,只要保留原作者、出处以及文中链接即可,任何网站均可摘要聚合,商用请联系授权。

CSS/CSS3 box-decoration-break属性图文简介

一、box-decoration-break属性简介

CSS box-decoration-break属性可以指定元素片段在跨行、跨列或跨页(如打印)时候的样式渲染表现。

默认情况下,元素的跨行或跨列渲染都是裁剪分割,各得一部分。

举个例子,如下HTML和CSS:

<div class="box">
  <span class="text">专门弄了个社交专用的微信号:zhangxinxu-job</span>
</div>
.box { width: 200px; color: #fff; }
.text { border-radius: 30px; background-color: #cd0000; }

结果如下(实时渲染):

专门弄了个社交专用的微信号:zhangxinxu-job

可以看到换行的位置是直直切割,圆角在最开始和最后面(如下截图箭头标记):

CSS/CSS3 box-decoration-break属性图文简介

有些丑!

设计师看不下去了,拿着40米的大刀走过来,说道:“哎呀,王哥,上面一行和下面一行两端都是圆角显然要更好看,可不可以实现啊?”

这个时候就体现出CSS基础知识的重要性了。

是可以实现的,就是借助CSS box-decoration-break属性。

CSS改动如下:

.box { width: 200px; color: #fff; }
.text { 
  border-radius: 30px; background-color: #cd0000;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

结果如下(实时渲染):

专门弄了个社交专用的微信号:zhangxinxu-job

可以看到断开的两个内联盒子两端都是圆角:

CSS/CSS3 box-decoration-break属性图文简介

二、box-decoration-break语法

在CSS布局中,总会存在元素box盒子断开的情况(page/column/region/line), box-decoration-break 可以决定断开时候的渲染表现。

当然,只能影响部分CSS的渲染,都有哪些呢?

  • background
  • border
  • border-image
  • box-shadow
  • border-radius
  • clip-path
  • margin
  • padding

等。

box-decoration-break 语法如下:

box-decoration-break: slice;  /* 默认值 */
box-decoration-break: clone;

其中

slice
slice是切片,分割的意思。默认值。表示各个盒子断开的部分如同切割开一般。
clone
clone是克隆,独立的意思。表示断开的各个盒子样式独自渲染。

三、跨列渲染demo案例

下面看一个跨列的样式案例。

如下HTML:

<div class="box">
    <p class="text">2018年...</p>
</div>

我们只要column布局使两列显示,同时设置p元素有边框:

.box {
    columns: 2;
}
.text {
    border: 5px solid #cd0000;
}

此时如下图,布局break处无边框,表现为slice。

CSS/CSS3 box-decoration-break属性图文简介

此时,我们设置 box-decoration-break 属性值为 clone ,结果会怎么样呢?在Firefox浏览器下如下:

CSS/CSS3 box-decoration-break属性图文简介

左右两栏内容分别呈现红色边框,符合我们的预期。

您可以狠狠地点击这里: box-decoration-break跨列布局渲染demo

//zxx: 经过测试,在Chrome浏览器下并没有表现出预期的效果,应该是渲染上的bug。把p标签改成span这种内联标签倒是有预期的效果,可惜按钮toggle样式的时候并不会重渲染,相信以后会修复这个问题的。

理论上CSS Regions布局也能有类似渲染,只是由于CSS Regions布局各大浏览器已经放弃了支持,本文不展示相关案例。

四、实际应用案例

借助 box-decoration-break 属性,我们可以实现不规则的内联文本整体渐变效果。

效果如下截图:

CSS/CSS3 box-decoration-break属性图文简介

您可以狠狠地点击这里: box-decoration-break文本不规则渐变demo

其中,关键CSS就是设置内联元素的 box-decoration-breakclone ,如下示意:

.text {
    padding: 5px;
    background-image: linear-gradient(to right, blue, red 200px);
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}

而默认状态下,内联元素换行渐变效果是这样的,上下行累加为一个渐变,而不是每一行都是渐变:

CSS/CSS3 box-decoration-break属性图文简介

五、兼容性、结语

CSS box-decoration-break 属性兼容性如下图:

CSS/CSS3 box-decoration-break属性图文简介

在移动端页面,包括小程序中可以放心使用。Android,Chrome等浏览器下还需要 -webkit- 私有前缀,Firefox浏览器完全支持。

没有结语。

CSS/CSS3 box-decoration-break属性图文简介

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。

本文地址: https://www.zhangxinxu.com/wordpress/?p=8346

(本篇完)


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

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创业者手册

创业者手册

[美] 史蒂夫·布兰克、[美] 鲍勃·多夫 / 新华都商学院 / 机械工业出版社 / 2013-1 / 89.00元

我们发现,企业的成功程度和创始人使用本书的频繁程度成正比。书中折角越多,书被翻得越破,企业取得的成功就越显著。阅读本书切忌囫囵吞枣。 所有创业者都坚信自己的道路与众不同,他们在踏上创业之路时从不设计路线图,认为其他模式或模板并不适合自己。同样是初创企业,有些能够取得成功而有些只能沦落到廉价清库的下场,看起来这似乎是运气使然,然而事实并非如此。英雄成功的故事都是一样的。初创企业实现成功之路肯定......一起来看看 《创业者手册》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具