当前位置:首页 > 技术 > 正文内容

ES6核心语法特性详解

访客 技术 2026年6月14日 1

变量声明机制的演进:let、const 与 var 的差异

ES6引入了块级作用域的变量声明方式,彻底改变了传统函数作用域的局限性。

  • var:存在变量提升,允许重复声明,作用域为函数级别。
  • let:禁止重复声明,不支持变量提升,作用域为块级。
  • const:用于定义常量,必须初始化,引用不可更改(但对象属性可变)。
// let 示例
{
  let count = 10;
  console.log(count); // 10
}
// console.log(count); // 报错:count 未定义

// const 示例
const API_URL = "https://api.example.com";
// API_URL = "https://new-api.com"; // 错误:不能重新赋值

const config = { timeout: 5000 };
config.timeout = 8000; // 允许修改属性
// config = {}; // 错误:不能改变引用
  

解构赋值:从数据结构中提取信息

通过简洁语法直接从数组或对象中获取所需值。

// 数组解构
const colors = ['red', 'green', 'blue'];
const [primary, secondary, tertiary] = colors;

// 对象解构
const user = {
  fullName: '李明',
  age: 25,
  hobbies: ['读书', '编程']
};
const { fullName, age } = user;
const [firstHobby, secondHobby] = hobbies;
  

模板字面量:增强字符串表达能力

使用反引号包裹字符串,支持换行和变量插值。

// 基本用法
const name = '小华';
const greeting = `你好,${name}!今天是星期几?`;

// 多行文本
const htmlTemplate = `
<div class="card">
  <h3>用户信息</h3>
  <p>姓名:${name}</p>
</div>
`;
  

箭头函数:更简洁的函数写法

采用 => 语法,简化函数定义,并具有隐式返回和上下文继承特性。

// 简化形式
const add = (a, b) => a + b;
const square = x => x * x;

// 无参/单参省略括号
const logHello = () => console.log('Hello');
const double = n => n * 2;

// 返回对象需加外层括号
const createUser = (name) => ({ name, role: 'user' });
  

关键特性:

  • 不绑定自身 this,捕获外部上下文的 this 值。
  • 不能作为构造函数,无 prototype 属性。
  • 没有 arguments 对象,推荐使用 ... 参数。

异步处理优化:摆脱回调嵌套

通过 Promise 实现链式调用,避免"回调地狱"问题。

// 传统嵌套回调(难以维护)
setTimeout(() => {
  console.log('第一步完成');
  setTimeout(() => {
    console.log('第二步完成');
    setTimeout(() => {
      console.log('第三步完成');
    }, 1000);
  }, 2000);
}, 1000);

// 使用 Promise 链式调用
new Promise(resolve => {
  setTimeout(() => {
    console.log('第一步完成');
    resolve();
  }, 1000);
})
.then(() => new Promise(resolve => {
  setTimeout(() => {
    console.log('第二步完成');
    resolve();
  }, 2000);
}))
.then(() => new Promise(resolve => {
  setTimeout(() => {
    console.log('第三步完成');
    resolve();
  }, 1000);
}));
  

模块系统:标准的代码组织方式

ES6原生支持模块化开发,实现文件级作用域隔离。

导出方式:

// 命名导出
export const PI = 3.14159;
export function calculateArea(radius) {
  return PI * radius ** 2;
}

// 默认导出(每个模块仅一个)
export default class Calculator {
  constructor() {}
  add(a, b) { return a + b; }
}
  

导入方式:

// 导入命名成员
import { PI, calculateArea } from './math.js';

// 导入全部内容
import * as mathUtils from './math.js';

// 导入默认导出
import Calculator from './calculator.js';

// 混合导入
import Calculator, { PI, calculateArea } from './module.js';

// 重命名导入
import { PI as piValue } from './constants.js';
  
标签: ES6

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。