请见代码,实现功能是要点表格当前行里的删除链接,直接删除当前行,并且删到最后一行的时候,把包含当前table的div直接隐藏了。
function delCurrentTr(){
//这两句一定要写在$(this)对象删除之前,否则$(this)对象执行删除后就取不到了。
var parentDiv = $(this).parents('.tbl-except');
var trCount = $(this).parent("td").parent("tr").siblings().size()+1;
//执行删除当前行操作
$(this).parent("td").parent("tr").remove();
//如果trCount放在这里才取值,是取不到了的,因为$(this)已经不存了。
//var trCount = $(this).parent("td").parent("tr").siblings().size()+1;
trCount --;
if(trCount==0){
//同理,在这里parentDiv再取值的话,也是取不到的
//var parentDiv = $(this).parents('.tbl-except');
parentDiv.hide();
}
}
注释掉的代码是面向对象的思维写的,昨天被坑了一个下午。
得到的理解就是在JS里删了就没了,没有什么对象引用之类的东西还留下(好像JAVA也是这样吧,对象没了,再通过对象的引用也是找不到与该对象相关的东西了)。