关于 ts 中继承的问题

2021-11-25 15:29:35 +08:00
 aglsv

我这块有四个文件,分别是 a ,ap ,b ,bp , 我最开始写的是 b 通过继承调用 a 里面的 init 方法,init 方法里面会调用执行 ap 里面的 drawAll 方法,但是这个时候再 bp 里面重写 drawImgBoxArea 方法的话并不会生效,

    public async init(): Promise<void> {
        await super.init()
        await this.selfPresenter.drawAll()
        this.addListener()
    }

之后我在 bp 里面写了个 drawAll 方法,里面通过 super 继承 b 的 drawAll 方法,再在 b 里调用 bp 的 drawAll ,这个时候重写 drawImgBoxArea 就会生效,

不过我在父类的 drawAll 里面最开始的时候会获取 imgList 然后赋值给 VM_ImgLis 变量,然而这么写的话我重写的 drawImgBoxArea 里面 console.log(this.VM_ImgList)的结果是空,获取不到父类的变量,

    public async drawAll(): Promise<void> {
        await super.drawAll()
    }
    public drawImgBoxArea(){
        console.log(this.VM_ImgList)
    }

我想问下这块是为什么啊。

1449 次点击
所在节点    TypeScript
2 条回复
noe132
2021-11-25 16:01:51 +08:00
看了 3 遍没看懂。

你第一次 drawAll 是在 bp 的实例上调用的吗?如果是在 ap 实例上调用,那和 bp 确实没啥关系啊

另外继承重写都是及物动词,需要加个谓语,调用方法是调用实例上的方法,你应该说明是哪个 class 的实例,而不是说那个文件里的方法,b 继承自 a 箭头不应该是 b 指向 a 么?
aglsv
2021-11-25 16:27:24 +08:00
@noe132 是我这没搞明白,第一次写这种继承类的东西,还是按照老思维在想。
每个文件我只 export default 一个 class ,就想当然的按照文件名字说了。文件名就是我的 class 类名,我这个结构就是在 a 里面实例化 ap ,之后调用,之后的 b 和 bp 都是继承自 class a 和 class ap ,相当于把 a 和 ap 当作基类来看

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/817929

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX