css transtion不生效_css 子元素transition动画为什么无效?

写了个模态窗口的飞入效果

提示

#mask{

display: none;

width: 100%;

height: 100%;

z-index: 100;

position: fixed;

background-color: rgba(0, 0, 0, 0.8);

text-align: center;

}

#tips{

position: absolute;

background-color: #0b93d5;

width: 600px;

height: 200px;

text-align: center;

top: 50%;

left: 50%;

margin-left: -300px;

margin-top: -100px;

font-size: 16px;

opacity: 0;

-webkit-transform:scale(3) ;

-moz-transform: scale(3);

-ms-transform: scale(3);

-o-transform:scale(3) ;

-webkit-transition: transform 0.8s ease-in,opacity 0.8s ease-in;

-moz-transition: transform 0.8s ease-in,opacity 0.8s ease-in;

-ms-transition: transform 0.8s ease-in,opacity 0.8s ease-in;

-o-transition: transform 0.8s ease-in,opacity 0.8s ease-in;

transition: transform 0.8s ease-in,opacity 0.8s ease-in;

}

$("#test").click(function(){

$("#mask").show();

$("#tips").css({

'-webkit-transform':'scale(1)',

'-moz-transform': 'scale(1)',

'-ms-transform': 'scale(1)',

'-o-transform':'scale(1)',

'opacity':1

});

将隐藏的mask显示后,tips直接显示动画最后的状态,整个动画的过程跳过了,但是我把mask的display:none去掉,再点击测试,动画效果正常。我在改变css属性前已经把mask显示了,原理上跟我第二种测试方法应该没有任何区别。找不到原因。。谁来解释下。。

更新:

我把$("#tips").css({

'-webkit-transform':'scale(1)',

'-moz-transform': 'scale(1)',

'-ms-transform': 'scale(1)',

'-o-transform':'scale(1)',

'opacity':1

});

用setTimeout(function(){},0)包裹起来结果就没问题了。。还是不知道是什么原因

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会为您解答关于html中transition属性和CSS3中Transition动画属性的用法。 在HTML中,transition属性表示元素在一定时间内从一种样式转换为另一种样式的过程。transition属性需要指定以下几个参数: - transition-property:指定过渡的CSS属性,可以使用all来表示所有属性都过渡。 - transition-duration:指定过渡的时间,以秒或毫秒为单位。 - transition-timing-function:指定过渡的时间函数,可以使用一些预定义的函数,如linear、ease、ease-in、ease-out等。 - transition-delay:指定过渡的延迟时间,以秒或毫秒为单位。 举个例子,如果您想让一个元素在鼠标悬停时变成红色,可以这样写: ``` div { background-color: blue; transition-property: background-color; transition-duration: 1s; transition-timing-function: ease-in-out; } div:hover { background-color: red; } ``` 这样,在鼠标悬停时,该元素的背景色会从蓝色平滑地过渡到红色。 在CSS3中,Transition动画属性是与transition属性相关的一组属性,包括以下几个参数: - transition-property:同HTML中的transition-property参数。 - transition-duration:同HTML中的transition-duration参数。 - transition-timing-function:同HTML中的transition-timing-function参数。 - transition-delay:同HTML中的transition-delay参数。 - transition: 简写形式,可以一次性指定以上所有参数。例如:transition: background-color 1s ease-in-out 0s。 此外,CSS3中还新增了一些过渡效果,包括旋转、缩放、平移等。举个例子,如果您想让一个元素在鼠标悬停时旋转180度并缩小一半,可以这样写: ``` div { width: 100px; height: 100px; background-color: blue; transition: transform 1s ease-in-out; } div:hover { transform: rotate(180deg) scale(0.5); } ``` 这样,在鼠标悬停时,该元素会以一个180度的旋转和50%的缩放平滑地过渡到新的状态。 希望这些内容能够帮到您,如果您还有其他问题,请随时提出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值