&nbs p;
一、长话短说
CSS 中有一个属性叫做 clip ,为修剪,剪裁之意。配合其属性关键字 rect 可以实现元素的矩形裁剪效果。此属性安安稳稳地存在于CSS2.1中,且使用上基本上没有类似于 max-h ei ght / dis play :table-cell 等浏览器的兼容性问题。但是,貌似大家很少使用此属性。我总结了三点 原因 :首先是理解上有些门槛;二是其他人使用的不多;三是此属性功能效果有不少替代 方案 。这种状态有些类似于普通的计算机使用者使用 xp系统 用得很不错,然后让他去使用 MAC系统 ,可能就会因为使用不习惯、其他人不怎么用、功能 xp 系统基本都有且支持更广泛而又回到XP系统上。实际上,哪种操作系统更好呢?我想不言而喻。
所以,我们使用 overflow 实现生硬的剪裁与原生的 clip 剪裁就有些类似于使用XP系统与Mac般。
老实讲,我自己使用的也不多,仅在两年前在实际项目中解决一些特殊的问题学习并使用了该属性。上个月的“CSS 相对/绝对(relative/absolute)定位 系列 (三 )”一文中的可用性隐藏部分曾出现了该属性的应用,其作用就是页面元素的可用性隐藏,相关CSS代码如下:
.hidden{ pos IT ion:absolute; clip: rect(1px 1px 1px 1px); /* IE6, IE7 */ clip: rect(1px, 1px, 1px, 1px); }
根据我自己的测试,貌似上面的第三行CSS是多余的。但是,这里出现是有其理由的,但是自己想不出了个缘由,还望他人指点迷津。
“美特斯邦威,不走寻常路”,正因为似乎大家都忽略了 clip 属性,所以我决定稍稍挖掘下 clip 的属性,让大家 开始 关注与熟悉此属性。顺带一句,这不是号召关心中华田园犬这种噱头成分颇多的东西,而是实在在的可以在实际项目中大放光彩的东东。
二、clip:rect属性亲密接触
根据Dre am weaver的自动提示, clip 有如下可用属性关键字:
其中,据说继承 inherit IE浏览器是不支持的,所以该属性就是个酱油帝;然后 "auto" 就是不剪裁之意,除了重置 rect 的作用外,其也是个酱油副帝;所以真正上得了台面张脸的就是 rect(top right bottom left) ,所以,我们下面只讨论 rect(top right bottom left) 这厮。
就顺序上而言, top → right → bottom → left ,在CSS中是 统一 相承的,就像是m arg in的四个值的顺序,border-width 等等 的四个值顺序——从头顶上开始,顺时针旋转的说~~ 不过 这里的四个值是不可以缩写的。
其中 top right bottom left 表示各个位置的属性值,就像是 width:200px; 中的 200px ,所以,我们会有类似下面的使用:
rect(30px 200px 200px 20px)
那这里的 top right bottom left 究竟指什么的?我们该如何理解呢?
其实是这样的, top right bottom left 分别指最终剪裁可见区域的上边, 右边 ,下边与左边。而所有的数值都表示位置,且是相对于原始元素的左上角而言的。于是
rect(30px 200px 200px 20px)
表示的含义就是:最终剪裁的矩形的上边 距离 原始元素的上边缘30像素;剪裁矩形的右边缘距离原元素左边缘的距离是200像素;剪裁矩形的下边缘距离原元素顶部的距离为200像素;剪裁矩形的左边缘距离原元素左边缘的距离时20像素。
上面的表述又长有啰嗦又难以理解,你可以这样想象:饥饿N天的你突然面前出现了块香喷喷的大大的300厘米*300厘米方形手抓饼,你拔出自己随着携带的锋利的日本刀,在距离顶部30厘米的地方咔嚓一刀,然后在距离左边200厘米的地方咔嚓一刀,然后又以迅雷不及掩耳的速度在距离顶部200厘米和距离20厘米的地方咔嚓一刀。啪啪四刀留下的中间的那块就是剪裁的内容了。所以,您可以将 top right bottom left 理解为在这些位置拿大刀咔咔修剪。
或者 理解为 在P hotoshop中为大背景建四个 方向 的 参考线 ,如下图(300像素*300像素)所示:
所谓“一图胜千言,千言不敌一实例”。为了更加直观的理解 clip:rect 后面四个值的含义,我专门做了个demo页面。您可以狠狠地点击这里:CSS clip:rect几个值含义示意demo
在demo页面中,我已经将4个值分离出来了,您任意修改其中的一个值,页面上就会出现 半 透明的黑色层示意这部分内容是将会被剪裁掉的。例如,我们修改第一个值为30,如下图:
失去 焦点 后就会看到图片上出现了改值对应的剪裁作用区域:
类似的,我们修改各个框框的值为 30 200 200 20 ,这时,图片上的效果就是:
其中图片中未被黑色半透明层覆盖的区域就是最后的剪裁区域,您可以点击下面的“剪裁”按钮确认剪裁,结果就如下图所示:
您也可以修改其他值做测试的。如果最后图片全部被半透明层覆盖,那么图片最后会被剪裁到 一点 不剩。
最后有必要说明下: clip:rect矩形剪裁只能作用于 position:absolute 的元素上 。
三、clip:rect矩形剪裁的一些应用介绍
1. 可用性隐藏
根据上 面对 top right bottom left 的释义,如果 left >= right 或者 bottom ,则元素会被完全裁掉而不可见,即“隐藏”。通过这种方式隐藏的元素是可以被屏幕 阅读器 等辅助设备识别的,从而 提高 了页面的可用性。
例如:
clip: rect(1px 1px 1px 1px); @H_ 777 _155@/*left = right, bottom = top*/
或
clip: rect(10px 10px 10px 100px); /*left > right*/
或
clip: rect(100px 10px 10px 10px); /*bottom
等,正所谓小手抖一抖,剪裁有木有。 //zxx:上面几个值的效果您可以去part2部分所提供的demo页面做测试滴。
2. img 标签下的CSS sprite 定位
为了节约图片资 源 ,我们经常会把小图片整合到一张图片上,称为图片合并技 术 , 国外 称为CSS S PR ite,含“精灵”之意。然后 利用 元素区域外 background 内容不可见的特性配合 background-position 定位实现图片的精确显示。
就连万万不能没有的钱都不是万能的,显然, background-position 下的CSS Sprite定位也不可能适用于各种情况。例如,有时我们希望Sprite图片可以延迟滚动加载,或者是可以很轻松的右键图片另存为 .. .或者是某些特殊的 background-position 属性不起作用的情况。
例如,众所周知的,IE6浏览器不支持Alpha透明通道的 png图片 (会有蓝蓝的背景),例如下图所示:
我们可以使用filter滤镜修复这一问题。然而,如果该png图片以background -i mage的形式滤镜透明化的话是不支持 background-position 定位的,也就是,我们不可能在IE6下使用background属性实现png图片的Sprite定位。此时,要想实现IE6下png图片的Sprite定位只能在页面上完成,使用img标签,而非 background-image 属性。
然后,img标签下的图片是不会像 background-image 一样元素区域外部分自动隐藏,所以,我们需要借助某些 手段 对齐进行裁剪,此时 clip:rect 就派上用场了。
您可以狠狠地点击这里:clip:rect下png图片Sprite定位demo
demo页面中的沙发png图片完整显示如下:
如果您手头上的浏览器为IE6浏览器,则打开demo页面会看到如下效果:
可以看到鼠标移上去后是有Sprite定位切换实现的hover效果:
可以看到为应用透明滤镜的情况下,使用 img 标签配合 clip:rect 轻松实现了Sprite图片的hover切换效果。这在background属性中也能实现,OK,现在点击下面的“IE6 png透明按钮”,应用 Alph ai mageLoader 透明滤镜,然后再鼠标经过,结果也是可以实现hover效果的,见下图:
CSS代码如下:
.clip_a{display:block; width:128px; height:128px;} .clip_a img{border:0; position:absolute; clip:rect(0 128px 128px 0);} .clip_a:hover{border:0;} .clip_a:hover img{mar gin -t op:-128px; clip:rect(128px 128px 256px 0);}
由此可见,CSS Sprite的定位不仅仅可以使用 background 属性,在页面上使用 img 标签,配合 clip:rect 剪裁也是可以轻松实现定位效果的。
3. 图片剪裁的预览效果
关于图像剪裁,很早前我曾 翻译 过一个名为Jcrop的 jQuery 插件, 文章 名为“ jq uery照片图像剪裁插件Jcrop中文翻译详解”,其中有个demo是含有剪裁预览效果的,您可以轻轻地点击这里访问。
里面的剪裁预览采 用M argin定位,有着较为复杂的计算。
实际上,像剪裁预览效果显示用剪裁属性来实现是最合适的了。于是,自己利用自己先前写的原生态的“ 图片旋转 +剪裁js插件”中的zxx.crop_rotation.j S写 了个图片剪裁预览效果demo。
您可以狠狠地点击这里:clip:rect图片剪裁效果demo
demo页面中的旋转可以直接当空气,移动,拖动示意区域,就会在右侧看到对应的剪裁预览效果:
此例旨在展示 clip:rect 的潜力,故原理与使用略,您有兴趣可参考上面提到的文章,以及demo页面相关源代码。
四、清明节前的唠叨
清明时节雨纷纷, 路上 行人欲断魂,看着天气像是要下雨的样子。今晚回乡,祭拜先祖。因为乡下没有安装 宽带 ,所以今天直接就在上班时间折腾这篇文章了,故结尾处可能略显仓促。另外,资质有限, clip:rect 的研究也不深,所以文中也难免有表述不准确的地方,欢迎指正,不甚感谢。
本文的几个 clip:rect 的应用实例纯属抛砖引玉,由于其本身功能的特殊性, clip 属性一定还有其他更加精妙的应用,这就要看你的智慧了。
得,就这些。祝“米娜桑”节日一切顺利。
(本篇完)
觉得 可用,就经常来吧! 欢迎评论哦! html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!
总结
以上是 为你收集整理的 html5教程-CSS clip:rect矩形剪裁功能及一些应用介绍 全部内容,希望文章能够帮你解决 html5教程-CSS clip:rect矩形剪裁功能及一些应用介绍 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于html5教程-CSS clip:rect矩形剪裁功能及一些应用介绍的详细内容...