开发者社区> 问答> 正文

什么情况下,用translate()而不用绝对定位?什么时候,情况相反。

什么情况下,用translate()而不用绝对定位?什么时候,情况相反。

展开
收起
茶什i 2019-11-18 17:00:04 1287 0
1 条回答
写回答
取消 提交回答
  • translate()是transform的一个值。改变transform或opacity不会触发浏览器重新布局(reflow)或重绘(repaint),只会触发复合(compositions)。而改变绝对定位会触发重新布局,进而触发重绘和复合。transform使浏览器为元素创建一个 GPU 图层,但改变绝对定位会使用到 CPU。 因此translate()更高效,可以缩短平滑动画的绘制时间。

    当使用translate()时,元素仍然占据其原始空间(有点像position:relative),这与改变绝对定位不同。

    2019-11-18 17:00:41
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载