CSS 函数的 8 个妙用

Ba la la la ~ 读者朋友们,你们好啊,又到了冷锋时间,话不多说,发车!


CSS 比许多 web 程序员认为的更加强大。这种样式表语言正变得越来越强大,给浏览器带来了原本要用 JavaScript 实现的功能。本文将介绍无需 JavaScript 的 CSS 函数的 8 个妙用。

1. 纯 CSS 的 tooltips

很多网站仍在用 JavaScript 创建 tooltips,但实际上,用 CSS 实现更加简单。最简单的方法是在 HTML 代码的 data 属性中提供 tooltip 文本,比如:data-tooltip="…"。这样就可以在 CSS 中添加以下代码来在 attr() 函数中显示 tooltip 文本了:

.tooltip::after {
content: attr(data-tooltip);
}

很好懂,对吧?当然要想设计 tooltips 还需要更多的代码,但是不必担心,有一款很棒的纯 CSS 库就是为此而生的,叫做 Hint.css 。

2. 使用自定义data 属性和 attr() 函数

我们已经在 tooltips 中用过 attr() 了,但是还有一些情况也可以用 attr()。结合 data 属性,可以通过 title 和 description 仅用一行 HTML 代码创建缩略图:

<a class="caption" href="#" data-title="Vulture" data-description="...">
<img src="img.jpg" alt="Illustration"/>
</a>

接下来就可以用 attr() 函数来显示 title 和 description 了:

.caption::after {
content: attr(data-title);
...
}

这里提供一个 hover 上去有字幕动画效果的缩略图例子:

http://codepen.io/SitePoint/pen/akAmPw

说明:CSS 生成的 content 是 不易获取 的。在此方面,这篇文章的 关于获取 CSS 生成 content 的内容(http://tink.uk/accessibility-support-for-css-generated-content/) 部分可以借鉴。


3. CSS 计数器

CSS 计数器可以做出神奇的效果。计数器不是最有名的特点,多数人可能认为它的支持性不够好,但实际上,所有浏览器都支持 CSS 计数器:

计数器用于分页或是在 gallery 下方展示项目数量都很棒,但是不应该用在有序列表(<ol>)上。也可以用 CSS 计数器计算已选项的数量,代码量会令你惊叹(并且没有 JavaScript):

http://codepen.io/lonekorean/pen/wKbzv

在可拖放排序的列表中用 CSS 计数器动态改变数量也很赞:

http://codepen.io/SitePoint/pen/bdeOKJ

像上个例子一样,记住——CSS 生成的 content 是不易获取的。

4. CSS filters实现毛玻璃效果

苹果的 iOS 7 给我们带来了“毛玻璃”效果——看起来像磨砂玻璃窗的、半透明、模糊的元素。在苹果的推行下,在越来越多的地方可以见到这种效果了。再现这种效果有点复杂——在有 CSS filters 之前,只能用 模糊的半透明图片 来实现毛玻璃效果。目前几乎所有的主流浏览器都支持 CSS filters,再现毛玻璃效果就简单多了 。

目前 backdrop filters 和 filter() 函数 只有 Safari 支持,但是将来我们就可以用它们实现相似的效果了。

5. HTML Elements做背景图

通常都是指定 JPEG 或 PNG 文件充当背景图或渐变。但是你知道 element() 函数可以用 <div> 做背景图吗?目前只有 Firefox 支持 element() 函数:

Element() 函数拥有无限可能,这里有个 MDN 上的 例子 。

6. calc() 实现智能栅格

Fluid grids(流体网格划分)很棒,但是有几个严重的问题。例如,无法实现顶部和底部的空隙和左右的空隙大小相同。此外,根据所使用的栅格系统不同,标记有些混乱。即使是 flexbox 也不是做好的解决方法。但是有了可在 CSS 中作为 value 使用的 calc() 函数,栅格会变得更棒。在 SitePoint 的此篇教程 中,George Martsoukos 列举了几个实例,比如间隔完美的网格画廊。通过 CSS 预编译器,比如 Sass,利用 calc() 实现一套栅格系统 非常简单,并且易于维护。calc() 的浏览器支持性近乎完美,极力推荐使用。

7. CSS calc() 对齐 position:fixed 元素

calc() 函数的另一个使用场景是对齐 fixed 定位的元素。例如,有一个左右均有空隙的 content wrapper,如果想要对 wrapper 内的一个 fixed 元素精准对齐——要算出给“right”或是“left”属性赋值多少是很困难的。用 calc() 可以结合 relative 和 absolute 的值来精准对齐元素:

.wrapper {
max-width: 1060px;
margin: 0 auto;
}
.floating-bubble {
position: fixed;
right: calc(50% - 530px); /* 50% - half your wrapper width */
}

这里提供一个例子:

http://codepen.io/SitePoint/pen/NAVRZQ

8. cubic-bezier() 动画

要想网站或 app 的 UI 更加引人注目的话,可以使用动画。但是标准的 easing 选项非常有限,比如“linear”或是“ease-in-out”。像是弹跳动画更是标准选项无法实现的。使用 cubic-bezier() 函数,就可以让元素按你想要的方式去动画。

使用 cubic-bezier() 有两种方式—— 理解背后的数学知识 然后自己创建,或者使用 cubic-bezier 生成器 。


以上为个人意见,如有雷同,纯属巧合,欢迎大家多提意见!Bey 了 个 Bey ~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,230评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,261评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,089评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,542评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,542评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,544评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,922评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,578评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,816评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,576评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,658评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,359评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,937评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,920评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,859评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,381评论 2 342

推荐阅读更多精彩内容

  • 随着css语言的广泛使用和不断发展,现在css能做的功能更加多样,而且相信随着时间的推移,也将更加强大。css是前...
    突然自我阅读 592评论 0 1
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,727评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,301评论 0 11
  • 一个学生问他老师:老师,昨晚我见一盲人打着灯笼走路。他明明看不见,打灯笼有何用?老师回答说,如果他是怕别人看不清路...
    许雄伟阅读 1,648评论 0 0
  • 其实就是我自己的一些经历,有一点小感悟,分享给大家。 今年四月份的时候,我父亲因病去世了,如今这世上就只剩我和我母...
    刘郎已恨蓬山远阅读 393评论 3 2