前端 - 请教一下CSS3中translateZ和rotateY书写顺序的问题
问题描述
<!DOCTYPE html><html><head><meta charset='utf-8'><title>translateZ测试</title><style>*{margin: 0; padding: 0;}/*父级p和子级p的样式*/.fa{width: 200px; height: 200px; border: 2px solid #000; margin: 100px auto; perspective: 800px;}.son{width: 100%; height: 100%; background: lime; font-size: 20px; text-align: center; -webkit-transform: translateZ(300px) rotateY(55deg);}</style></head><body> <p class='fa'><p class='son'>rotateY</p> </p> </body></html>
当先执行rotateY,后执行translateZ时,(-webkit-transform: translateZ(300px) rotateY(55deg);)截图:
当先执行translateZ,后执行rotateY时,(-webkit-transform: rotateY(55deg) translateZ(300px);)截图:
请问为什么translateZ和rotateY书写顺序不同,结果也不同,这其中的原理是什么呢?我看了《图解CSS3》,也百度了相关内容,但还是不知道为什么。请知道的朋友给讲讲,谢谢!
问题解答
回答1:这部分我前几天刚看,也是研究老半天,应该是z轴始终是与平面图形垂直的,先转换角度的话,z轴的方向也相应发生变化。
回答2:脑子里构建个XYZ轴或者画一个,然后拿手比划比划我觉得是最好最方便的理解方式
回答3:很简单:
向右转,向前走5步
和
向前走5步,向右转
到达的位置是不一样的
回答4:我理解的是:在没有做任何变换时 元素都是在translate3d三维的世界 x y z轴的原点,不管做任何变换 坐标系都不会变的,第一种情况是 先转55度 在沿着z平移到300px(类似于扭着身子向前走了300px); 而第二种情况是 先平移出来 然后在绕着坐标的Y轴旋转(类似于做半径是300的圆周运动)
相关文章:
1. 为什么span的color非要内联样式才起作用?2. docker start -a dockername 老是卡住,什么情况?3. html5 - H5做的手机分享页微信更新后,分享出去不再默认显示第一个图 作为缩略图4. 关于docker下的nginx压力测试5. golang - 用IDE看docker源码时的小问题6. 小白问题getDay()7. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战8. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?9. 老师,请问我打开browsersync出现这个问题怎么解决啊?10. mysql问题请教

网公网安备