V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
aglsv
V2EX  ›  TypeScript

关于 ts 中继承的问题

  •  
  •   aglsv · 2021-11-25 15:29:35 +08:00 · 1461 次点击
    这是一个创建于 1097 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我这块有四个文件,分别是 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)
        }
    

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

    第 1 条附言  ·  2021-11-26 10:39:47 +08:00
    搞懂了,是调用的时候的 this 指向的问题
    noe132
        1
    noe132  
       2021-11-25 16:01:51 +08:00 via Android
    看了 3 遍没看懂。

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

    另外继承重写都是及物动词,需要加个谓语,调用方法是调用实例上的方法,你应该说明是哪个 class 的实例,而不是说那个文件里的方法,b 继承自 a 箭头不应该是 b 指向 a 么?
    aglsv
        2
    aglsv  
    OP
       2021-11-25 16:27:24 +08:00
    @noe132 是我这没搞明白,第一次写这种继承类的东西,还是按照老思维在想。
    每个文件我只 export default 一个 class ,就想当然的按照文件名字说了。文件名就是我的 class 类名,我这个结构就是在 a 里面实例化 ap ,之后调用,之后的 b 和 bp 都是继承自 class a 和 class ap ,相当于把 a 和 ap 当作基类来看
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   6037 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 02:16 · PVG 10:16 · LAX 18:16 · JFK 21:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.