这篇文章发布于 2015年02月15日,星期日,22:23,归类于 CSS相关。 阅读 37476 次, 今日 4 次 4 条评论
by zhangxinxu from http://www.zhangxinxu.com
本文地址:http://www.zhangxinxu.com/wordpress/?p=4638
一、兼容性地矩阵变换效果
IE9+支持CSS3 transform变换,IE9需要-ms-
私有前缀,但是IE6-IE8怎么办呢?
在“IE矩阵滤镜Matrix旋转与缩放及结合transform的拓展”一文中曾提到一个CSS3 transform转换成IE矩阵滤镜工具:IE’s CSS3 Transforms Translator,于是我们可以在web上实现各种兼容性的transform
变换效果。
然而,IE的Matrix矩阵变换,或者zoom
缩放会改变元素原本占据的展示尺寸,位置等,与CSS3优雅的transform
完全不一样,导致,我们需要对IE做额外的偏移。上面提到的工具就自动计算出了应有的margin偏移大小
但是,我们大多数人的数学都是体育老师交的,计算偏移值什么的,想想就大头娘娘了,难道,就不能跟CSS3 transform一样,就规规矩矩居中放大吗?
童鞋,略施小计,还是有办法滴。
二、基于中心点的IE zoom缩放或矩阵变换
原理如下
内嵌一个巨大的海洋般宽广的大容器,然后,让里面的元素在这个海洋般宽广的容器中水平且垂直定位即可。
代码示意
.outer { /* 外部可视区域容器 */ width: 100px; height: 100px; position: relative; overflow: hidden; } .container { /* 里面宽广的海洋 */ width: 1000px; height: 1000px; position: absolute; left: 50%; top: 50%; margin: -500px 0 0 -500px; }
实例-元素hover
放大效果
要实现效果为hover图片,然后可是区域不变,里面图片信息放大。
您可以狠狠地点击这里:鼠标hover元素scale/zoom中心点放大效果demo
demo页面有上下两个示意,上面一个为普通的定位实现,下面为使用“广阔海洋”技术的实现,在IE9以上浏览器下,由于是使用纯正的CSS3 transform
实现,因此,是看不出差异的。
但是,在IE8之流浏览器下,你会看到前后差异了,例如,传统定位实现,hover图片放大,则不是中心点放大,而是左上角,不是我们想要的效果:
但是,下面这张图片,hover时候图片就是以中心点放大,是我们想要的效果,棒棒哒!
实现的关键
实现的关键是海洋内部需要变换元素的水平垂直居中效果,要兼容IE7,我所知道的办法就是inline-block
化,水平居中让容器text-align
, 垂直居中实现是再造一个高度100%
, vertical-align: middle
的隐形元素,具体可参见demo页面上展示的源代码。
三、IE其他矩阵变换
如果要实现其他变换效果,例如兼容的旋转效果,也是类似的“海洋布局”策略。不具体展示。
奇怪,原来上一篇不是年前的最后一篇文章。
本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:http://www.zhangxinxu.com/wordpress/?p=4638
(本篇完)
- 理解CSS3 transform中的Matrix(矩阵) (0.444)
- 小tip:CSS vw让overflow:auto页面滚动条出现时不跳动 (0.354)
- IE矩阵滤镜Matrix旋转与缩放及结合transform的拓展 (0.302)
- 趁热打铁,SVG feColorMatrix滤镜gogogo! (0.283)
- 理解SVG transform坐标变换 (0.160)
- 小tips: 在canvas上实现元素图片镜像翻转动画效果 (0.160)
- 借助SVG文字尺寸自动缩放甚至突破Chrome 12px限制 (0.142)
- JS之我用单img元素实现了图像resize拉伸效果 (0.142)
- Pixi.js中ColorMatrixFilter自带滤镜效果一览 (0.142)
- 小tips: zoom和transform:scale的区别 (0.120)
- absolute元素在text-align属性下的对齐显示 (RANDOM - 0.101)
请教大神。为什么我写的demo,用海洋布局的图片会偏左一点呢?
这里介绍的方法就可以实现基于中心的变换了呀:http://www.useragentman.com/IETransformsTranslator/
为什么还要用这个“海洋布局”法?
@子顾 通用性。文中的方法代码可以整站、整个中国,整个宇宙通用。但是,定值修正不同的使用场景需要不同的值去修改。而且,如果遇到动画效果,就折腾了!
如果能兼容动画效果就更好了,加上duration,deylay,ease