CSS translate3d(x,y,z)

admin發表於2018-08-08

translate3d() 方法用來規定指定元素在三維空間中的位移效果。

用法比較簡單,本文將通過一段程式碼例項動態演示 translate3d 效果。

與二維空間位移相比,增加 Z 軸的位移,具體參閱 CSS3 translate(x,y) 一章節。

transform 變換更多內容參閱 CSS3 2D/3D轉換 一章節。

語法結構:

[CSS] 純文字檢視 複製程式碼
transform:translate3d(x,y,z)

引數解析:

(1).x:表示在 x 軸方向的位移。

(2).y:表示在 y 軸方向的位移。

(3).z:表示在 z 軸方向的位移。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼執行程式碼
<!DOCTYPE html>  
<html>  
<head>  
<meta charset=" utf-8">  
<meta name="author" content="http://www.softwhy.com/" />  
<title>螞蟻部落</title>  
<style>
#box{
  position:relative;
  height:150px;
  width:150px;
  margin-left:450px;
  margin-top:250px;
  padding:10px;
  border:1px solid black;
  perspective:1200px;
}
#ant{
  width:100px;
  height:100px;
  text-align:center;
  line-height:100px;
  font-size:12px;
  border:1px solid black;
  background-color:yellow;
     
  transform:translate3d(0px,0px,0px);
}
table{   
  font-size:12px;   
  width:500px;   
  margin-left:220px; 
  text-align:left; 
}   
.left{
  text-align:right;
  width:150px;
}
</style>
<script type="text/javascript">  
function change(x,y,z){  
  var odiv = document.getElementById("ant");
  var oshow = document.getElementById("show");
  odiv.style.transform = "translate3d(" + x + "px," + y + "px," + z + "px)";
  oshow.innerHTML = x_range.value + "/" + y_range.value + "/" + z_range.value;
} 
window.onload=function(){ 
  var x_range = document.getElementById("x_range");
  var y_range = document.getElementById("y_range");
  var z_range = document.getElementById("z_range");
  x_range.onmousemove = function () {
    change(x_range.value, y_range.value, z_range.value);
  }
  y_range.onmousemove = function () {
    change(x_range.value, y_range.value, z_range.value);
  }
  z_range.onmousemove = function () {
    change(x_range.value, y_range.value, z_range.value);
  }
} 
</script> 
</head>
<body>
<div id="box">
  <div id="ant">螞蟻部落</div>
</div>
<table>  
  <tr>  
    <td class="left">x軸位移:</td>  
    <td><input type="range" min="-200" step="1" max="200" id="x_range" value="0"/></td>  
  </tr>  
  <tr>
    <td class="left">y軸位移:</td>
    <td><input type="range" min="-200" step="1" max="200" id="y_range" value="0" /></td>
  </tr>
  <tr>
    <td class="left">z軸位移:</td>
    <td><input type="range" min="-200" step="1" max="200" id="z_range" value="0" /></td>
  </tr>    
  <tr>  
    <td class="left">x/y/z:</td>  
    <td>(<span id="show">0/0/0</span>)</td>  
  </tr>  
</table>  
</body>  
</html>

上面的程式碼結合JavaScript演示了translate3d方法的功能。

特別說明:如果不使用perspective屬性,將看不到z軸演示效果,因為3D場景就不會有景深的Z軸。

perspective屬性參閱CSS3 perspective一章節。 

translate3d方法也可以拆分單獨寫:

[CSS] 純文字檢視 複製程式碼
transform:translateX(10px); 
transform:translateY(20px); 
transform:translateZ(30px);

相關文章