html的table的子节点,HTMLTableElement子节点并不如预期

我最近开始使用类型脚本,对不起,如果它是一个该死的问题。HTMLTableElement子节点并不如预期

我想添加事件监听器表本身,而是侦听行click事件(在我的表中的所有行是动态生成的,除了标题行)

验证码:

的Html

PassengersClientBooking File NameBooking FilePNREvolvi RefBookings IDBooking TypeCar Hire VoucherConsultantSupplierStatusScanIDHandOff StatusRe-HandOff

脚本类型

class class SearchAllFormUIX {

constructor() {

this.addListeners();

}

addListeners() {

var searchResultTable: HTMLTableElement = document.getElementById("searchResultTable");

searchResultTable.onclick = this.propertyChanged;

}

propertyChanged = (event: MouseEvent) => {

var target: HTMLElement = event.target;

if (target.getAttribute("id") == "searchResultTable") {

alert(target.parentNode.nodeName); // DIV

for (var i = 0; i < target.childNodes.length; i++) {

alert(target.childNodes[i].nodeName);

// target.childNodes[0] = #Text

// target.childNodes[1] = TBODY

}

}

}

}

而问题是这样的 - 为什么HTMLTableElementchildNodes是#Text和TBODY而不是tr, td ...等等???

P.S.即使它是静态html,代码的行为也是相同的,所以我没有包含生成表的代码。 P.P.S.父节点是然而正确显示 - DIV

UPD 问题solwed。 为了访问表元素的休息 - 下要做到:

for (var i = 0; i < target.childNodes.length; i++) {

if (target.childNodes[i].nodeName == "TBODY") {

for (var j = 0; j < target.childNodes[i].childNodes.length;j++) {

if (target.childNodes[i].childNodes[j].nodeName == "TR") {

alert(target.childNodes[i].childNodes[j].textContent);

}

}

}

}

希望这可以帮助其他人。

2016-01-21

Sasha

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值