这篇文章发布于 2015年06月4日,星期四,01:51,归类于 CSS相关。 阅读 68035 次, 今日 4 次 16 条评论
by zhangxinxu from https://www.zhangxinxu.com
本文地址:https://www.zhangxinxu.com/wordpress/?p=4831
一、支持良久的text-decoration-line
text-decoration
顾名思意就是“文字装饰”的意思,我们平常使用多的就是链接无划线或者hover下划线,也就是:
a { text-decoration: none; } a:hover { text-decoration: underline; }
或者就是团购网站里面,原价¥100, 这个¥100需要被删掉状,于是,就直接使用<del>
标签,或者使用span标签,然后如下text-decoration
值:
span { text-decoration: line-through }
当然,text-decoration
在CSS2.1时代,支持的属性值不仅仅上面出现的这几个,还有与underline
对应的overline
, 表示上划线,虽然兼容性不错,但是似乎没有什么卵用,鄙人不才,写CSS这么多年一次都没有在实际项目中使用过overline
.
然后,还有一个blink
, 就是text-decoration:blink
, 看名字似乎很霸气,不过我们好像很少见到,更别说使用了,为啥子?
首先,这个text-decoration
的装饰效果是,闪烁。由于鄙人没见过,也不好描述具体是个什么效果。为什么我没有见过呢!我查了下资料,原来虽然此属性值躺在规范里,但是,木有浏览器支持这个效果。哦,抱歉,FireFox曾经是支持的,后来可能破坏了府里的规矩,也就乖乖不支持了。于是,现在,大家很难见到text-decoration:blink
究竟是个什么效果了。
text-decoration
是支持多值的。比方说:
.multiple { text-decoration: underline overline; }
上横线和下划线同时出现了。
但是,今天我一测试才发现,原来text-decoration
的多值特性连IE7浏览器也支持,真是学习了!
补充于2019-02-09
今天测试发现,父子元素同时设置text-decoration
属性,居然效果是累加的。
然后,我就突发奇想,这文字上面一条线,下面一条线,要是再和border
上面一条线下面一条线搞在一起,会有什么怎样的表现呢?
于是,整了个测试Demo, 您可以狠狠地点击这里:text-decoration和border和outline关系
结果在宋体下,FireFox/Chrome浏览器下,text-decoration
线和border
线和outline
线,正好密不可分缠绵在一起,1像素也不侵占,如下:
但是在IE浏览器下,IE7~IE11, 或者所有浏览器的微软雅黑字体下,下划线和边框线是有距离的,如下:
但是,无论什么字体,什么浏览器,inline元素的上横行和上边框和上外框都是紧密连接在一起的。有人可能会疑问,有个卵用?嘿,你还别说,说不定什么时候想实现某图形生成效果的时候,会有奇用。
OK, 本节的underline/overline
等,实际上在新的text-decoraction
仅仅是其中text-decoration-line属性值,只是text-decoraction
的一部分。
二、新的text-decoration-style类型
上一节讲的都是老CSS的故事,在CSS3时代,text-decoration
也发生了一些进化,首先就是文字装饰的类别变多了。以前就是线啊线的,要么上边线,要么中间横个线,或者下划线。现在牛大了,不仅可以是虚线、点线、双线、甚至是波浪线。
text-decoration-style: solid; text-decoration-style: double; text-decoration-style: dotted; text-decoration-style: dashed; text-decoration-style: wavy; text-decoration-style: inherit;
三、text-decoration-color定义装饰线的颜色
以前text-decoration
的颜色是跟着color走的,我们是不能修改的。但是,现在,新出来了个text-decoration-color
, 我们可以愉快地定义装饰线的颜色……这样的场景,需要等到浏览器足够兼容才行。
目前最近几个版本的FireFox浏览器无压力支持text-decoration-color
, 但是Chrome浏览器还需要去chrome://flags
手动开启“启用实验性网络平台功能”才可以支持。
兼容性如下:
三、文字和线的覆盖关系text-decoration-skip
text-decoration-skip
表示,当字符和装饰线发生重叠关系的时候,例如,删除线,或者一些英文字符(g, q)和下划线,我们的装饰线是跳过文字字符,还是直接连在一起穿过去。举个例子吧,如下CSS:
a { text-decoration-skip: ink; }
可能最后的表现会是这样:
text-decoration-skip
支持的一些值以及含义如下:
objects
: 默认值。 装饰线跳过内联对象,比方说图片啊或者inline-block
元素。none
: 装饰线穿过一切,包括本应跳过的内联对象。spaces
: 装饰线跳过空格或字符间分隔,以及letter-spacing
或word-spacing
形成的间距。ink
: 装饰线跳过符号或下沉字母。edges
: 装饰性起始于内容起始边缘后面,结束语内容结束边缘的前面。这个属性值的目的是为了让两个搞在一起的下划线元素看上去公用一条下划线。这对于中文字体很有用,因为会使用下划线作为标点符号。box-decoration
: 装饰线跳过继承的margin
,border
, 以及padding
.trailing-spaces
: 装饰线跳过pre
或white-space: pre-wrap
里面前后空格。
效果如下图示意:
这个属性看上去很牛很强很有用,不过有个不幸地消息要告诉大家,目前还没有什么浏览器支持这个属性。
不过,目前,存在一种有人问津的情况。在最新的OSX和iOS下,Safari浏览器默认对装饰线的穿越规则进行了修改,默认就是类似text-decoration-skip: ink;
的效果,我们可以使用下面这行CSS进行重置:
-webkit-text-decoration-skip: none;
这就是目前唯一的与text-decoration-skip
有响应的使用场景,不过,估计很快,大家就能愉快地玩耍了。
四、text-decoration的缩写
我们目前使用的text-decoration
实际上是种缩写,完整的,应该包括:text-decoration-line
, text-decoration-style
, text-decoration-color
等。例如:
text-decoration: underline wavy red;
至于浏览器支不支持,则是另外一回事了。
最后,当下搬运工,大家可以同下面这个例子,感受text-decoration
的一些新特性和新表现。
五、想不出标题的结束语
因为太晚了,我已经没有什么想吐槽的了。
明天发工资了,happy~
明天还有看电影的活动,happy~
还有个摊子要收拾……恩……紧上眉头……
明天是地铁上班呢还是其他交通工具?
鱼缸里的河蚌记得提醒老婆明天放生~~
……
本文为原创文章,部分图片以及demo参考自”More Control over Text Decoration“,转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:https://www.zhangxinxu.com/wordpress/?p=4831
(本篇完)
- 解决文字和text-decoration:underline下划线重叠问题 (0.283)
- 好消息,CSS text-underline-offset可以用起来了 (0.283)
- CSS实现文字下面波浪线动画效果 (0.226)
- 去除inline-block元素间间距的N种方法 (0.208)
- word-break:break-all和word-wrap:break-word的区别 (0.151)
- 小tip:中文英文左右padding一致两端对齐实现 (0.113)
- CSS text-decoration实现宽度100%波浪线效果 (0.113)
- 翻译-高质量JavaScript代码书写基本要点 (0.057)
- 拜拜了,浮动布局-基于display:inline-block的列表布局 (0.057)
- web页面相关的一些常见可用字符介绍 (0.057)
- 小tips: 使用 等空格实现最小成本中文对齐 (RANDOM - 0.057)
现在是2019-02-11,使用chrome71 `text-decoration-skip` 属性没有了, 内置一个`text-decoration-skip-ink` 属性
然而好像还是不支持和文字的距离调整?
新出了一个 text-underline-offset属性,调整下划线和文字的距离
老师你好,text-decoration会随字体的大小而改变粗细,
如我写了一个
ABOUT TECHNOLOGE,
h2 { text-decoration:underline; font-size:20px; },span { font-size:24px; },
它们的下划线粗细不一致。
后来我这么改
ABOUT TECHNOLOGE,
h2 { font-size: 18px; }
h2 span { display: inline-block; border-bottom: 1px solid #000; }
h2 span:first-letter { font-size: 24px; }
截图
http://pan.baidu.com/s/1o70lxai
http://pan.baidu.com/s/1bore7QB
不知老师有没有更好的方法o(^▽^)o
@jyzeng 试试使用border模拟
这位同学在做百度IFE前端任务吧,我也遇到这个问题了,可以在HTML中写成小写的单词但是第一个字母大写,CSS中用font-variant属性,所有的小写字母均会被转换为大写,已经使用大写字母的文本字体会更大,这样下划线不会变粗。
text-decoration: underline;
text-decoration-style: dotted;
-moz-text-decoration-style: dotted;
貌似很多浏览器不支持???鑫哥,测试过兼容性吗?
涨知识了
汗~~刚看到新属性就跑去试了试,后来发现后文说了暂且没有浏览器支持,我说text-decoration-skip:ink;怎么看不到效果呢~~
谢谢旭哥,学到了不少…..旭哥可以出书了…
用ipad uc打开demo直接闪退
不要乱放生
鑫旭大哥真是高产啊,感觉自己一天的时间都在处理工作,都没有时间学习了。
师兄,关于测试Demo text-decoration和border和outline关系
我也测试了一下,在最新版chrome(版本 43.0.2357.81 m)里面,效果是这样的: http://imgur.com/qiszkhg
我看到的是 underline overline 同border刚好紧贴在一起,显示出来
@神仙 对的,是这样的,没有贴在一起是IE浏览器以及所有浏览器的微软雅黑字体。Chrome下宋体是贴在一起的,你可能阅读时候没看清楚。
我只对 放生 两个字 感兴趣。