将javascript转换为TypeScript时出现问题

时间:2019-04-29 07:33:08

标签: javascript typescript typescript2.0

打字稿中的语法问题。我用JavaScript编写了代码,然后尝试将其放入ts文件中。进行了一些更改,但仍然显示单元问题。

class X {
  public appendTableColumn() {
    var tbl = <HTMLTableElement>document.getElementById("myTable"); // table reference
    //var colnum= parseInt(tbl.rows[0].cells.length) - 1;
    // i;
    var m = parseInt(tbl.rows[0].cells.length) + 1;
    // open loop for each row and append cell
    for (var i = 0; i < tbl.rows.length; i++) {
      var k = parseInt(i) + 1;

      //createCell(tbl.rows[i].insertCell(tbl.rows[i].cells.length), "R"+ tbl.rows.length +"C"+ k, 'col');
      this.createCell(
        tbl.rows[i].insertCell(tbl.rows[i].cells.length),
        "",
        "col",
      );
      var x = document.getElementById("myTable").rows[i].cells;
      var btnName = "R" + k + "C" + m;
      x[tbl.rows[i].cells.length - 1].id = "td" + btnName;
      x[tbl.rows[i].cells.length - 1].innerHTML =
        '<button class="button" onclick="reply_click(this.id);" id=' +
        btnName +
        ">Manage Items</button>";
      //alert(btnName);
    }
  }
}

1 个答案:

答案 0 :(得分:0)

document.getElementById仅保证返回HTMLElement,但是您暗含期望它是一个表,而TypeScript无法保证它是因为它不会查看您的HTML代码(在其中其他原因)。

当您具有这样的元素类型假设时,您需要做的是使用类型断言。

var x = (<HTMLTableElement>document.getElementById("myTable")).rows[i].cells;

顺便说一句,您不需要将类型number的变量传递给parseInt。以下行:

var m = parseInt(tbl.rows[0].cells.length) + 1;
// ...
var k = parseInt(i) + 1;

应改为:

var m = tbl.rows[0].cells.length + 1;
// ...
var k = i + 1;