0

0

解决JavaScript继承中父类方法无法访问的TypeError

聖光之護

聖光之護

发布时间:2025-07-08 17:34:13

|

306人浏览过

|

来源于php中文网

原创

解决javascript继承中父类方法无法访问的typeerror

本文旨在帮助开发者解决在JavaScript类继承中遇到的“Uncaught TypeError: (intermediate value).updateUI is not a function”错误。通过分析问题原因和提供解决方案,本文将指导读者正确地在子类中调用和扩展父类方法,避免常见的继承陷阱。

在JavaScript中使用class关键字进行面向对象编程时,继承是一种强大的特性,允许子类继承父类的属性和方法。然而,在实际开发中,有时会遇到子类无法访问或调用父类方法的情况,导致TypeError。本文将深入探讨这种问题的常见原因以及相应的解决方案。

问题分析

在提供的代码示例中,RosterTableUtil是父类,RosterSchedulerTableUtil是子类。父类RosterTableUtil的constructor中定义了一个名为updateUI的函数,并将其赋值给this.updateUI。子类RosterSchedulerTableUtil试图通过super.updateUI(cellIndex, rowIndex)调用父类的updateUI方法,但却出现了“Uncaught TypeError: (intermediate value).updateUI is not a function”错误。

立即学习Java免费学习笔记(深入)”;

问题根源在于父类updateUI的定义方式。在constructor内部使用this.updateUI = (cellIndex, rowIndex) => { ... } 定义的函数,实际上是在创建实例属性,而不是定义类的方法。 虽然在父类实例中可以访问,但是在子类中通过super调用时,由于作用域和this指向的问题,会导致找不到该方法。

解决方案

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载

为了解决这个问题,应该将updateUI定义为类的实例方法,而不是在构造函数中赋值。以下是修改后的代码示例:

class RosterTableUtil {
  #highLightCellIndex = -1
  #highLightRowIndex = -1;

  updateUI (cellIndex, rowIndex) {
    this.#highLightCellIndex = cellIndex;
    this.#highLightRowIndex = rowIndex;
    console.log(`RosterTableUtil row ${this.#highLightRowIndex}, cell ${this.#highLightCellIndex}`);
  }
}

class RosterSchedulerTableUtil extends RosterTableUtil {
  updateUI (cellIndex, rowIndex) {
    super.updateUI(cellIndex, rowIndex);
    // do other stuff
  }
}

const util = new RosterSchedulerTableUtil();
util.updateUI(1,2);
util.updateUI(3,4);

代码解释

  1. 将updateUI定义为类的方法: 将updateUI函数直接定义在RosterTableUtil类的constructor外部,这样它就成为了类的实例方法。
  2. 使用super关键字调用父类方法: 在子类RosterSchedulerTableUtil的updateUI方法中,使用super.updateUI(cellIndex, rowIndex)正确地调用父类的updateUI方法。

注意事项

  • this的指向: 在JavaScript中,this的指向取决于函数的调用方式。在类的方法中,this指向类的实例。
  • super关键字: super关键字用于调用父类的构造函数或方法。在子类的构造函数中,必须先调用super()才能访问this。
  • 私有字段: 代码中使用了 #highLightCellIndex 和 #highLightRowIndex 作为私有字段,这是ES2022引入的特性,可以有效防止外部直接访问和修改类的内部状态。

总结

在JavaScript类继承中,正确地定义和调用父类方法至关重要。通过将方法定义为类的实例方法,并使用super关键字进行调用,可以避免TypeError,并实现代码的复用和扩展。理解this的指向以及super关键字的用法,是掌握JavaScript面向对象编程的关键。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

65

2025.11.27

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

65

2025.11.27

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

65

2025.11.27

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

931

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
JavaScript高级框架设计视频教程
JavaScript高级框架设计视频教程

共22课时 | 3.7万人学习

前端学科面试题大全(第一季)
前端学科面试题大全(第一季)

共26课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号