Typescript 从Array 继承时碰到的问题

class TestArray extends Array<number>
{
    private _values;
    constructor(value) {
        super();
        this._values = value;
       
    }

    TestMethod() {
        alert("hello, world");
    }
}

var testArr = new TestArray([]);
testArr.TestMethod();

上面的代码可以编译通过,运行时提示TestMethod不存在,在构造函数中加上Object["setPrototypeOf"](this, TestArray.prototype); 就好了。

相关的链接

https://github.com/Microsoft/TypeScript/wiki/FAQ#why-doesnt-extending-built-ins-like-error-array-and-map-work

 

https://stackoverflow.com/questions/14000645/extend-native-javascript-array

 

标准的Error, Array, Map 都有这个问题。

 

class TestArray extends Array<number>
{
    private _values;
    constructor(value) {
        super();
        this._values = value;
        Object["setPrototypeOf"](this, TestArray.prototype);
    }

    TestMethod() {
        alert("hello, world");
    }
}

var testArr = new TestArray([]);
testArr.TestMethod();

 

转载于:https://www.cnblogs.com/KruceCoder/p/10550593.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeScript array 是用来存储多个相同类型的元素的数据结构。在 TypeScript 中,我们可以使用以下方式来定义和操作数组: 1. 定义数组:使用 `[]` 或 `Array<elementType>` 来定义一个数组变量。 ```typescript let myArray: number[] = [1, 2, 3]; // 定义一个包含数字的数组 let anotherArray: Array<string> = ["Hello", "World"]; // 使用泛型定义一个包含字符串的数组 ``` 2. 访问数组元素:使用索引值来访问数组中的元素,索引从 0 开始。 ```typescript let firstElement = myArray[0]; // 访问第一个元素,值为 1 ``` 3. 修改数组元素:通过索引修改数组中的元素。 ```typescript myArray[1] = 5; // 修改第二个元素的值为 5 ``` 4. 遍历数组:可以使用循环语句或 `forEach` 方法来遍历数组中的元素。 ```typescript for (let i = 0; i < myArray.length; i++) { console.log(myArray[i]); } myArray.forEach(element => { console.log(element); }); ``` 5. 数组方法:TypeScript 提供了一些常用的方法来操作数组,例如 `push`、`pop`、`splice`、`concat` 等。 ```typescript myArray.push(4); // 在数组末尾添加一个元素 let removedElement = myArray.pop(); // 移除并返回数组末尾的元素 myArray.splice(1, 1); // 从索引为 1 的位置删除一个元素 let newArray = myArray.concat(anotherArray); // 合并两个数组 ``` 这些是 TypeScript数组的基本用法,还有更多高级操作和方法可以参考 TypeScript 官方文档。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值