`
yiminghe
  • 浏览: 1461439 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

兼容 ie 的 transform

 
阅读更多

css 2d transform 是 css3 引入的一个新的 css 属性,特别是可以很方便对元素进行旋转和扭曲变换,摆脱了传统枯燥的方方正正的形象,很好玩,但其实 ie 早就支持这种变化了,通过 matrix 滤镜在一些限制条件下完全可以达到同样的效果.

 

兼容

 

从角度转化为 matrix 滤镜所需要的矩阵值涉及基础的坐标旋转方面的知识,可参考 wiki . 简单举例:

 

假设对应 css3 rotate(30deg),那么只要将以下矩阵值赋给 matrix filter 对应元素并设置 SizingMethod='auto expand' 即可:

 

rad=30*Math.PI/180;

 

[

   cos rad, -sin rad

   sin rad,  cos rad 

]

 

问题

 

但 ie 设置滤镜后并不是和 css3 完全对照,存在一些差异

 

1. ie 下旋转会改变该元素的 layout,进而影响整个文档流

 

例如 100*200 的元素(红点表示中心点)

 

 

在旋转 60 度后会变成 224*187,ie 会选择一个最小的矩形来渲染旋转后的元素

 

 

那么其周围的元素都会受其影响.这点就意味着,为了达到 css3 同样的效果就需要该元素为绝对定位。

 

2. ie 旋转点不固定

 

css3 transform 是绕着 transform-origin 进行变化,从而保持 transform-origin 所代表的点在坐标中保持不变:

 

 

而 ie 的原则却是始终保持旋转后的矩阵左上角和原始矩阵对齐,如图2 所示.

 

 

而无论绕哪个点旋转,最终经过坐标平移一个值后总可以使得旋转后图像重合(证明本次略过)。那么只要找到该值,将 ie 旋转后的图像整体平移后即可达到对应 css3 的效果。

 

注意到旋转前后中心点的位置是已知的(图中红点)

 

准备

 

坐标平移到原始元素矩阵左上角,即原始元素矩阵左上角为坐标原点 (0,0) ,那么原始中心点为

 

 

(w/2,h/2)

 

(w,h为旋转前原始元素的宽高)。

 

ie 旋转后的矩阵左上角坐标仍为

 

(0,0)

 

那么原始中心点为 

 

 

(w'/2 ,h'/2)

 

(w',h' 为ie旋转后的矩阵宽高)。

 

css3

 

如果按照 css3 算法,原始 router 要绕 transform-origin 来旋转,假设为

 

(ox,oy)

 

那么再次进行坐标旋转,原点为 (ox,oy),那么旋转前中心点为:

 

 

(w/2-ox,h/2-oy)

 

中心点旋转后坐标为

 

 

(cx',cy') = m*(w/2-ox,h/2-oy)

 

(m 为先前计算的变化矩阵)

 

在原始元素矩阵左上角为坐标原点情况下坐标为:

 

 

(cx'+ox,cy'+oy)

 

平移修正

 

而 ie 旋转后中心点坐标为 

 

 

(w'/2,h'/2)
 

那么 ie 需要平移 

 

 

(cx'+ox-w'/2 , cy'+oy-h'/2)

 

才能符合 css3 的算法。

 

具体到如何平移,则可以通过 marginTop/marginLeft ,也可以通过 left/top。

 

 

demo

 

简单的钟摆

 

还有一个有趣过时的 ie hack:圆形绘制

 

  • 大小: 1.3 KB
  • 大小: 6.3 KB
  • 大小: 4.4 KB
分享到:
评论

相关推荐

    详解vue 兼容IE报错解决方案

    以下将详细解释在使用Vue.js时,如何解决兼容IE所遇到的问题和报错。 首先,需要了解IE浏览器对于现代JavaScript的ECMAScript 6 (ES6) 和ECMAScript 2015 (ES2015) 规范中引入的新特性并不完全支持。Babel是一个...

    兼容ie的平面百叶窗轮播

    "兼容ie的平面百叶窗轮播"是一种特殊类型的轮播效果,旨在确保在旧版本的Internet Explorer(IE)浏览器上也能正常运行。在现代浏览器如Chrome、Firefox、Safari等使用WebKit内核的浏览器中,这种效果通常能获得更好...

    纯css多级下拉菜单兼容ie6+主流浏览器

    本文将深入探讨如何使用纯CSS实现兼容IE6+及主流浏览器的多级下拉菜单,帮助Web开发者提升用户体验,同时简化开发流程。 首先,让我们了解CSS(层叠样式表)的基本概念。CSS是一种用于描述HTML或XML(包括如SVG、...

    推拉门式菜单-兼容ie,ff

    总之,一个兼容IE和FF的推拉门式菜单需要考虑多方面的因素,包括HTML结构的合理性、CSS的跨浏览器编写和JavaScript的事件处理与动画实现。通过对这些方面进行精细调整和优化,我们可以创建出既美观又具有良好兼容性...

    javascript 旋转时钟 使用rotate属性 transform 兼容版本

    虽然现代浏览器普遍支持这些特性,但老版本的Internet Explorer(IE9及以下)需要使用`-ms-transform`。因此,确保代码如下: ```javascript element.style.transform = 'rotate(' + θ + 'deg)'; element.style....

    文字无间断向上滚动,兼容ie6

    标题"文字无间断向上滚动,兼容ie6"描述了一种技术实现,即在网页上实现文字持续不断地向上滚动,同时确保这个效果在古老的Internet Explorer 6(简称IE6)浏览器上也能正常工作。这在早期互联网时代尤其重要,因为...

    兼容IE8的jQuery旋转木马幻灯片插件

    本文将深入探讨如何创建一个兼容IE8的jQuery旋转木马(Carousel)幻灯片插件,以及涉及的相关知识点。 1. **jQuery核心概念**: - **选择器**:jQuery提供了一系列强大的选择器,如ID选择器 (#id),类选择器 (....

    IE兼容CSS3

    例如,IE9不支持CSS3的transform、transition和animation等特效,这些在其他浏览器中已经成为标准。 为了解决这个问题,我们可以使用一个名为“Modernizr”的JavaScript库。Modernizr是一种开源工具,它可以检测...

    js兼容ie8的选项卡.rar

    本项目"js兼容ie8的选项卡.rar"提供了一个解决此问题的实例,主要针对选项卡组件的实现。以下将详细介绍其中涉及的知识点: 1. **DOM操作**: IE8不支持W3C标准的`document.createElement()`, `appendChild()`, `...

    3D层叠轮播图(原生js,兼容ie9及以上,可用于vue和react项目)

    本项目就是这样一个实现,它不仅兼容IE9及以上版本的浏览器,而且还能无缝集成到Vue和React这样的现代前端框架中。 首先,让我们深入了解3D层叠轮播图的核心技术。3D层叠效果通常涉及CSS3的`transform`属性,尤其是...

    一个图片居中的CSS示例,兼容IE6,7,8和FF,opera,safari

    在IE6和7中,`transform`属性不被支持,但我们可以使用`expression`来实现类似的效果: ```css .container img { position: absolute; top: expression((this.offsetHeight - parent.offsetHeight) / 2 + 'px'); ...

    javascript 旋转图片 兼容IE和FireFox

    总之,这个示例提供了在JavaScript中兼容IE和Firefox的图片旋转解决方案,利用了CSS3的`transform`和IE的滤镜技术。通过分析`rotationPicture.js`,我们可以更深入地了解这些技术是如何结合在一起工作的。

    IE10兼容性白皮书

    ### IE10兼容性白皮书关键知识点解析 #### 一、HTML5增强用户体验的关键特性 **1. Canvas元素:** - **定义:**Canvas 元素是 HTML5 中新增的一项强大功能,允许开发者在页面上绘制图形。 - **优势:** - 可以在...

    FF和IE兼容性问题

    FF和其他现代浏览器对CSS3新特性如`border-radius`、`box-shadow`、`transform`等有较好的支持,而老版本的IE则需要使用专有的`-ms-`前缀,或者依赖于`Microsoft’s CSS Expression`。 解决这些问题通常需要使用...

    IE兼容ES6解决办法。。。。。。。。。。。

    然而,这些新特性在旧版浏览器,尤其是Internet Explorer (IE) 中并不支持,这给开发者带来了兼容性问题。为了解决这个问题,我们可以采用以下策略: 1. **Babel 转换**: - Babel 是一个广泛使用的JavaScript...

    CSS兼容IE和Firefox的技巧集合

    CSS兼容性问题在Web开发中一直是个棘手的挑战,尤其是在处理IE(尤其是IE6、IE7)和Firefox之间的差异时。以下是一些针对这些浏览器兼容性问题的CSS技巧: 1. **垂直居中问题**: 当你需要一个div内容垂直居中时,...

    DIV+CSS网页中IE和火狐兼容问题的整理

    - IE浏览器对CSS3新属性的支持较晚,如`transform`、`transition`、`border-radius`等。 - Firefox、Chrome等浏览器对CSS3有较好的支持。 解决方法:使用浏览器前缀 `-webkit-`, `-moz-`, `-ms-`, `-o-` 来分别...

    兼容ie8的jquery圆形弹出按钮菜单插件

    针对“兼容ie8的jquery圆形弹出按钮菜单插件”,我们可以深入探讨jQuery的使用,以及如何构建兼容旧版浏览器(如IE8)的前端组件。 首先,jQuery库的核心功能包括选择器、事件处理、动画效果和Ajax操作。对于这个...

    Js 实现的幻灯片效果 兼容 IE FF

    5. **兼容性处理**:由于JavaScript在不同浏览器中的实现可能存在差异,特别是对于老版本的Internet Explorer (IE)和Firefox,我们需要确保代码具有良好的浏览器兼容性。这可能涉及到使用polyfills(用于提供缺失...

Global site tag (gtag.js) - Google Analytics