我使用javascript insertRow()
方法将一行插入表中。这只是正常 - 见普拉克使用表插入时CSS转换不起作用行
http://plnkr.co/edit/XNwQswZCrYYb8t10HgzP?p=preview
我的问题是,我想申请一个CSS过渡到插入。所以我认为最好的方法是添加行,应用0px的高度,插入innerHTML
,然后将高度设置为50px。我已经在CSS中设置tr转换为transition: height 1s;
问题是,转换不起作用。
CSS:
tr {
transition: height 1s;
-webkit-transition: height 1s; /* Safari */
}
的javascript:
var opentr;
function showStrAdd(index) {
var tableRef = document.getElementById('atable').getElementsByTagName('tbody')[0];
var html = "<td colspan='3'>hello world!</td>";
if(opentr!==undefined){
tableRef.deleteRow(opentr);
}
opentr = parseInt(index)+1;
var row = tableRef.insertRow(opentr);
row.style.height = "0";
row.innerHTML=html;
row.style.height = "50px";
};
HTML:
<table border="1" id="atable">
<tbody>
<tr>
<td>0 r1c1</td>
<td>r1c2</td>
<td>r1c3
<button onclick="showStrAdd(0)">click</button>
</td>
</tr>
<tr>
<td>1 r2c1</td>
<td>r2c2</td>
<td>r2c3
<button onclick="showStrAdd(1)">click</button>
</td>
</tr>
<tr>
<td>2 r3c1</td>
<td>r3c2</td>
<td>r3c3
<button onclick="showStrAdd(2)">click</button>
</td>
</tr>
</tbody>
</table>
任何想法?
什么是动画? –
是的,过渡工作在tr。只有低的高度不 – vals
@CraigMorgan相同的规则 –