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

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

内容简介: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

(本篇完)


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

查看所有标签

猜你喜欢:

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

构建高性能Web站点

构建高性能Web站点

郭欣 / 电子工业出版社 / 2012-6 / 75.00元

《构建高性能Web站点(修订版)》是畅销修订版,围绕如何构建高性能Web站点,从多个方面、多个角度进行了全面的阐述,几乎涵盖了Web站点性能优化的所有内容,包括数据的网络传输、服务器并发处理能力、动态网页缓存、动态网页静态化、应用层数据缓存、分布式缓存、Web服务器缓存、反向代理缓存、脚本解释速度、页面组件分离、浏览器本地缓存、浏览器并发请求、文件的分发、数据库I/O优化、数据库访问、数据库分布式......一起来看看 《构建高性能Web站点》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具