news 2026/4/23 13:04:30

ES6对象方法简写:更简洁的代码写法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ES6对象方法简写:更简洁的代码写法

ES6 中为对象字面量引入的「方法简写」语法,这是 ES6 简化对象写法的重要特性之一,能让对象方法的定义更简洁。

方法简写的核心概念

在 ES5 及更早版本中,定义对象方法需要明确写出属性名: 函数的形式;而 ES6 的方法简写则允许直接省略function关键字和冒号,让写法更接近类的方法定义,更简洁直观。

1. 基础用法对比

先通过对比看核心区别:

javascript

运行

// ES5 定义对象方法 const objES5 = { name: "张三", sayHello: function() { console.log("你好,我是" + this.name); }, add: function(a, b) { return a + b; } }; // ES6 方法简写 const objES6 = { name: "张三", // 省略 : function,直接写方法名+(){} sayHello() { console.log("你好,我是" + this.name); }, add(a, b) { return a + b; } }; // 调用方式完全一致 objES5.sayHello(); // 输出:你好,我是张三 objES6.sayHello(); // 输出:你好,我是张三 console.log(objES6.add(2, 3)); // 输出:5
2. 结合计算属性名的进阶用法

方法简写还能和 ES6 的「计算属性名」结合,定义动态名称的方法:

javascript

运行

const methodName = "greet"; const person = { name: "李四", // 动态方法名 + 方法简写 [methodName + "World"]() { console.log(`${this.name}:Hello World!`); } }; person.greetWorld(); // 输出:李四:Hello World!
3. 注意事项
  • 方法简写定义的是普通函数,不是箭头函数,因此this的指向遵循普通对象方法的规则(指向调用该方法的对象);
  • 不能在方法简写中使用箭头函数替代(箭头函数没有自己的this,会绑定外层作用域的this),比如下面的写法是错误的(或不符合预期):

    javascript

    运行

    const badObj = { name: "王五", // 错误示范:箭头函数的this不指向badObj sayHello: () => { console.log(this.name); // 输出:undefined } };
  • 方法简写仅适用于对象字面量,不能用于对象原型或类的静态方法之外的场景(类的方法本身就是类似简写的形式)。

总结

  1. ES6 方法简写的核心是省略对象方法定义中的: function,直接用方法名() { ... }形式,简化代码书写;
  2. 简写方法的this指向调用该方法的对象,区别于箭头函数;
  3. 可结合计算属性名实现动态方法名的简洁定义,是日常开发中最常用的 ES6 特性之一。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 1:54:37

MiDaS深度解析:1元体验SOTA模型,技术小白也能懂

MiDaS深度解析:1元体验SOTA模型,技术小白也能懂 你是不是也经常看到“SOTA模型”、“单目深度估计”这类术语就头大?论文一打开,满屏数学公式和专业名词,瞬间劝退。但其实,这些听起来高大上的AI技术&#…

作者头像 李华
网站建设 2026/4/18 12:05:47

强烈安利9个AI论文工具,本科生轻松搞定论文写作!

强烈安利9个AI论文工具,本科生轻松搞定论文写作! 论文写作的“救星”正在悄然改变你的学习方式 在当今这个信息爆炸的时代,本科生面对论文写作的压力日益增大。从选题到资料收集,再到撰写与修改,每一个环节都可能让人感…

作者头像 李华
网站建设 2026/4/20 4:35:00

C++:实现字符编码转换utf-8/gbk(附带源码)

一、项目背景详细介绍在实际软件开发过程中,字符编码问题几乎是所有 C/C 程序员绕不开的“经典难题”。尤其在以下场景中,编码问题尤为突出:Linux / Windows 跨平台开发网络通信(HTTP、Socket)旧系统(GBK&a…

作者头像 李华
网站建设 2026/4/23 12:42:34

AutoGLM-Phone-9B量化部署:2块钱体验压缩版手机AI助手

AutoGLM-Phone-9B量化部署:2块钱体验压缩版手机AI助手 你有没有想过,让一个AI助手帮你自动操作手机?比如你说“帮我查一下今天的天气”,它就能自己打开天气App并读出结果;或者“把昨晚拍的照片发给妈妈”,…

作者头像 李华
网站建设 2026/4/17 6:40:11

程序员接单实用指南:平台选择、真实体验与避坑思路

欢迎来到我的博客,代码的世界里,每一行都是一个故事🎏:你只管努力,剩下的交给时间 🏠 :小破站 程序员接单实用指南:平台选择、真实体验与避坑思路程序员接单之前,需要先想…

作者头像 李华