好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-CSS3 linear-gradient线性渐变实现虚线等简单实用图形

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、作为图片存在的 CSS 3 gra die nt渐变

我 觉得 CSS3 Backgrounds比较厉害的一个地方就是支持多背景,也就是背景图片个数可以无限累加,正好CSS3的gradient渐变性质是 background -i mage ,于是,我们可以实现任意数量渐变背景图的叠加效果。甚至,理论上,任意彩色 jpg 图片都是可以使用CSS3渐变背景实现的。

这种特性和 box -s hadow 类似,参见“CSS3 box-shadow盒阴影图形生成技 术 ”, text-shadow 也有无限累加性,通常我们可以实现任意粗细和色彩的描边效果。

当然我们实际开发的时候,是不会使用CSS3渐变来模拟一张图片的,更多是用来生成一些 简单 实用的图形。

本文就将通过实现虚线,三角以及加号减号等案例,展示下CSS3 linear-gradient线性渐变要图形生成技巧。

二、CSS3 linear-gradient线性渐变生成比例可控虚线及工具

我们平常要实现一个虚线效果,多 半 是使用 border-style:dashed 声明实现,然而虚线边框有一个问题,那就是虚线的实虚比例是固定的,例如,Ch rom e和Firefox浏览器下,颜色区的 宽 高比是3:1,颜色区和透明区的宽度比例是1:1:

IE浏览器下颜色区的宽高比是2:1,颜色区和透明区的宽度比例也是2:1,如下:

如果有设计需求,希望我们的虚线颜色区的宽高比是5:1,此时, border-style:dashed 就鞭长莫及了。

此时,借助CSS3 linear-gradient 线性渐变我们可以轻松实现上面的效果,假设HT ML 代码如下:

<div class="dashed"></div>

则对应的CSS代码如下:

.dashed {     h ei ght: 1px;     background: linear-gradient(to right,  # 000000, #000000 5px, transparent 5px, transparent);      background-size : 10px 100%; }

效果截图如下:

当我们使用CSS3渐变来构建图形的时候,最画龙点睛的属性,其实并不是渐变本身,而是 background-size 属性,让我们的图形约束在特定区域大小。

关于线性渐变生成虚线,我特意 制作 了一个CSS代码生成工具,您可以狠狠的点击这里:基于CSS3线性渐变实现的虚线CSS生成工具demo

我们可以选择你希望的虚线的比例,步幅以及颜色,然后对应的CSS代码就可以生成了,例如:

有兴趣的话可以手动试一试。

二、CSS3 linear-gradient线性渐变生成带线框的三角

做到 三角图形的生成,最经典的 应该 是使用CSS border 属性了,可参见“CSS border三角、 圆 角图形生成技术简介”一文,如果是纯色三角,使用CSS3 clip-path 也是一个不错的方法,关于clip-path 文章 参见这里。

但是有时候我们的三角是带线框的,类似下图这种效果:

如果不考虑兼容性,比较好的做法是 border 属性生成两侧线框,然后CSS3 transform 旋转,但也有局限,那就是如果和三角对接的区域它不是纯色而是渐变背景,则就有问题了,因为此时的三角实际上是个旋转45度的正方形图形块。

此时使用渐变图形生成方法就没有任何 压力 了,因为可以得到一个真正的三角(135度斜向渐变到对角线位置),示意图如下:

相关CSS代码如下(这里线框也是渐变实现的):

.tri {     width: 6px; height: 6px;     background: linear-gradient(to top, #ddd, #ddd) no-re PE at, linear-gradient(to right, #ddd, #ddd) no-repeat, linear-gradient(135 deg , #fff, #fff 6px, hsla(0,0%,100%,0) 6px) no-repeat;     background- Size:  6px 1px, 1px 6px, 6px 6px;     transform: rotate(-45deg); }

眼见为实,您可以狠狠的点击这里:基于CSS3线性渐变三角图形生成demo

更新记录(10-29): transparent 6px → hsla(0,0%,100%,0) 6px ,新升级Firefox下transparent边缘会有灰色背景渲染bug,使用rgba或hsla 白色 透明表示可修复。

三、CSS3 linear-gradient线性渐变生成加号和减号

要实现一个减号效果非常简单,例如要实现一个10px*2px的减号图形,则CSS:

.minus {     background-image: linear-gradient(to top, #666, #666);     background-size: 10px 2px; }

原理如下,先使用渐变生成一个铺满整个元素背景的纯色(#666)渐变图片,然后使用 background-size 属性控制成我们想要的大小,效果就实现了。

加号效果也是类似,只是要多一层 linear-gradient 的累加。

最终可以实现类似下图效果:

@H_646_ 126 @

和传统 :: before , ::afetr 伪元素配合 background-color 或 border 相比,使用渐变背景生成有个非常 重要 的好处,那就是居中定位非常方便,直接在 background 属性后面加个 center 即可,而传统实现通常需要绝对定位,然后再巴拉巴拉一通代码来居中,很啰嗦的。

眼见为实,您可以狠狠的点击这里:基于CSS3线性渐变加号和减号图形demo

四、结束语

本文可以说是渐变图形生成最基本入门,有个比较著名的CSS纹理网站CSS3 Patterns Gallery,这里面这些地方基本上全部都是使用CSS3渐变实现的,不仅有线性渐变,还有径向渐变。

有兴趣的话可以看看,比如说 了解 一些全面的 实现原理 等,但实际开发的时候,我们其实用的并不多,反而是本文介绍的这些基础的简单实用图形更加受益。

对于径向渐变,我目前玩得还不是很深入,等以后发现好玩的东西给大家介绍。

好,就这些内容吧,权当抛砖引玉。

(本篇完)

觉得可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-CSS3 linear-gradient线性渐变实现虚线等简单实用图形 全部内容,希望文章能够帮你解决 html5教程-CSS3 linear-gradient线性渐变实现虚线等简单实用图形 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-CSS3 linear-gradient线性渐变实现虚线等简单实用图形的详细内容...

  阅读:51次