欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

transform 的副作用

程序员文章站 2022-04-09 19:08:57
transform是一些效果的集合,主要是移动、旋转、缩放和倾斜这四种基本操作,还可以通过设置matrix矩阵来实现更复杂的效果。 变形transform可以实现2D和3D两种效果。 变形transform本来是一个用来处理移动、旋转、缩放和倾斜等基本操作的CSS3属性,但该属性除了完成其本职工作之 ......

transform是一些效果的集合,主要是移动、旋转、缩放和倾斜这四种基本操作,还可以通过设置matrix矩阵来实现更复杂的效果。

变形transform可以实现2d和3d两种效果。

变形transform本来是一个用来处理移动、旋转、缩放和倾斜等基本操作的css3属性,但该属性除了完成其本职工作之后,还对普通元素造成了意想不到的影响,本文将详细介绍transform对元素造成的四个副作用:

一、z-index

在定位中的堆叠z-index中曾经提到过,css3的出现对过去的很多规则发出了挑战,对层叠上下文z-index的影响更加显著,其中就包括元素的变形transform不是none的情况

元素的变形transform不是none,会使该元素可以使用堆叠z-index,从而可以覆盖普通流元素和低级别的定位元素。

show2和show1都是普通元素,show2通过设置margin负值,覆盖了show1。但是,通过改变show1的'transform'属性可以改变其层叠效果。

1.show1 - transform: none

transform 的副作用

2.show1 - transform: scale(1)

transform 的副作用

二、fixed

固定定位fixed使元素相对于视窗进行定位,不随着页面滚动条的滚动而滚动。但是,如果在固定定位元素的父级设置transform不为none,则会将固定定位降级为绝对定位absolute

兼容性:ie浏览器无此表现,依然保持fixed状态

[注意]在chrome浏览器下,将固定定位元素父级的transform属性设置为none,可能会使元素从静态位置移动到left:0、top:0的位置。如果某个父级元素设置为宽度100%,则fixed将保持在原来位置不会改变

1.show1父类 - transform: none

transform 的副作用

2.show1父类 - transform: scale(1)

transform 的副作用

 

 

三、overflow

对于溢出overflow失效的情况,发生在overflow在绝对定位元素及其包含块之间,如下所示

transform 的副作用

 

给设置overflow的元素使用transform或在设置overflow的元素与溢出元素之间的元素设置transform,可以解决overflow失效的问题。

兼容性:在chrome和safari浏览器下,只有设置overflow的元素与溢出元素之间的元素设置transform时,才有效;而ie9+和firefox浏览器,对于以上两种设置都有效。

[注意]在chrome浏览器下,将元素的transform属性设置为none,可能会使元素从静态位置移动到left:0、top:0的位置

1.设置overflow元素/中间层元素 - transform: none

 transform 的副作用

2.设置overflow元素/中间层元素 - transform: scale(1)

transform 的副作用

四、定位父级

一般地,绝对定位元素设置宽度百分比时,参照的是定位父级。定位父级是第一个position值为非static值的祖先元素。但是,如果祖先元素中存在设置了transform元素不为none的元素,也可以成为定位父级

以下为例子中的html结构,当中间层 midlde-block 元素设置transform:scale(1)时,该元素成为定位父级,否则.parent元素是定位父级

 transform 的副作用