javascript类如何定义_ES6类语法如何使用?
发布时间 - 2026-01-09 00:00:00 点击率:次ES6 class必须用new调用,直接调用报错;子类constructor必须首行调用super();方法不可枚举且不绑定this;静态与实例方法可同名但需区分调用方式。
class 声明必须用 new 调用,不能当普通函数执行
ES6 的 class 本质是语法糖,底层仍基于原型,但设计上强制要求使用 new。直接调用会报错:
class Person {
constructor(name) {
this.name = name;
}
}
Person('Alice'); // TypeError: Class constructor Person cannot be invoked without 'new'这个限制能避免意外丢失 this,也和内置类(如 Date、Array)行为一致。如果真需要“可选 new”的构造逻辑,得回退到传统函数 + arguments.length 判断,但那就不是标准 class 了。
constructor 不写也会隐式存在,但继承时必须显式调用 super()
空 class Foo {} 等价于 class Foo { constructor() {} };但一旦子类 extends 父类,且定义了 constructor,就必须第一行写 su,否则报错:
per()
class Animal {
constructor(name) {
this.name = name;
}
}
class Dog extends Animal {
constructor(name, breed) {
// 必须写,否则 ReferenceError: Must call super constructor
super(name);
this.breed = breed;
}
}漏掉 super() 或调用位置不在首行,都会触发严格错误。注意:即使父类没有显式 constructor,子类的 constructor 里仍需 super() —— 因为隐式构造器也需要初始化 this。
方法默认不可枚举,且不绑定 this,箭头函数写法要小心
class 内定义的普通方法(包括 constructor)会自动添加 enumerable: false 属性,所以 for...in 或 Object.keys() 都遍历不到它们。另外,这些方法不会自动绑定 this:
class Button {
constructor(label) {
this.label = label;
}
handleClick() {
console.log(this.label);
}
}
const btn = new Button('OK');
document.addEventListener('click', btn.handleClick); // this 指向 window 或 undefined(严格模式)常见解法有三:
- 在事件绑定时用
btn.handleClick.bind(btn) - 在 constructor 中赋值:
this.handleClick = this.handleClick.bind(this) - 用箭头函数声明方法:
handleClick = () => { ... }(注意:这是类字段语法,需额外支持)
静态方法和实例方法不能同名,且 static 方法无法被实例调用
class 中可以用 static 定义静态方法,它属于类本身,不属于实例:
class MathUtils {
static add(a, b) {
return a + b;
}
add(a, b) {
return a + b + 1;
}
}
MathUtils.add(1, 2); // 3(走静态方法)
const m = new MathUtils();
m.add(1, 2); // 4(走实例方法)但注意:静态方法和实例方法**可以同名**,JS 引擎靠调用方式区分。不过这容易引发混淆,实际项目中应避免。另外,m.add() 能调用实例方法,但 m.constructor.add() 才能访问静态方法——别指望 m.add() 自动 fallback 到 static 版本。
# javascript
# es6
# java
# js
# win
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
免费网站制作appp,免费制作app哪个平台好?
如何快速搭建二级域名独立网站?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
使用spring连接及操作mongodb3.0实例
如何在IIS中配置站点IP、端口及主机头?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何在阿里云虚拟服务器快速搭建网站?
如何在IIS中新建站点并配置端口与物理路径?
如何用免费手机建站系统零基础打造专业网站?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
Python正则表达式进阶教程_复杂匹配与分组替换解析
html如何与html链接_实现多个HTML页面互相链接【互相】
如何破解联通资金短缺导致的基站建设难题?
香港服务器选型指南:免备案配置与高效建站方案解析
网站图片在线制作软件,怎么在图片上做链接?
Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】
Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
无锡营销型网站制作公司,无锡网选车牌流程?
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
如何快速搭建高效服务器建站系统?
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
Laravel怎么调用外部API_Laravel Http Client客户端使用
常州企业网站制作公司,全国继续教育网怎么登录?
如何在宝塔面板中修改默认建站目录?
Laravel如何集成Inertia.js与Vue/React?(安装配置)
Android GridView 滑动条设置一直显示状态(推荐)
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
JavaScript中的标签模板是什么_它如何扩展字符串功能
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
动图在线制作网站有哪些,滑动动图图集怎么做?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Laravel如何与Pusher实现实时通信?(WebSocket示例)
Java解压缩zip - 解压缩多个文件或文件夹实例
如何在Windows服务器上快速搭建网站?
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
EditPlus中的正则表达式实战(5)
iOS验证手机号的正则表达式
敲碗10年!Mac系列传将迎来「触控与联网」双革新
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤

