typescript之prototype

参考

https://www.runoob.com/js/js-object-prototype.html

直接代码说话吧:

function person() {}
person.prototype.test = function () {
  console.log(this.a)
}

let per1 = new person()
per1.a = '456'
per1.test()   // 456
person.prototype.test() //undefined

per1.test = function () {
  console.log('123')
}
per1.test()  //123
per1.prototype.test() //TypeError: Cannot read property 'test' of undefined



通过上面代码可以看出:

1、当对象实例可以有test函数的时候,就执行当前的test函数 。如果找不到的话,就去prototype上面去找。

2、在对象实例上面无法直接调用prototype对象

per1.__proto__

另外我们可以看下person对象在运行时候的堆栈信息。

第一个test 应该是当前实例上的函数,第二个test是prototype上面的test函数。

per1.__proto__.test()   //undefined

上述的方法也可以调用prototype上面的test对象,但是获取不到this.a的值,这个应该是当前的this指向了__proto__对象了。

这里还有一种用法,如下:

person.test2 = function () {
  console.log('test2')
}
person.test2() //test2
per1.test2()   //TypeError: per1.test2 is not a function

这种用法的话,那么test2函数和我们实例的对象就完全没有关系了。只可以在person函数上面调用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeScript中,可以使用`.prototype`来定义对象的原型属性和方法。在JavaScript中,`.prototype`可以用于创建对象的原型链,使得对象可以共享相同的属性和方法。 通过使用`.prototype`,我们可以给对象添加自定义的属性和方法。当对象实例调用这些方法时,会首先在对象自身上查找该方法,如果找不到,则会继续在原型链上查找。 下面是一个示例代码: ```typescript function Person() {} Person.prototype.test = function () { console.log(this.a); } let per1 = new Person(); per1.a = '456'; per1.test(); // 456 Person.prototype.test(); // undefined per1.test = function () { console.log('123'); } per1.test(); // 123 // 错误示例,不能通过实例的原型调用方法 // per1.prototype.test(); // TypeError: Cannot read property 'test' of undefined ``` 在这个示例中,我们创建了一个名为`Person`的构造函数,并通过`.prototype`给`Person`添加了一个`test`方法。然后,我们通过`new`关键字创建了一个`Person`的实例`per1`,并给`per1`添加了一个属性`a`。当我们调用`per1.test()`时,会先在`per1`对象本身查找`test`方法,然后再在`Person.prototype`上查找。因此,`per1.test()`的结果是`456`。而`Person.prototype.test()`的结果是`undefined`,因为该方法在调用时没有绑定到任何对象。 总结来说,`.prototype`可以用于在TypeScript中定义对象的原型属性和方法,实现属性和方法的共享和继承。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值