ES6 核心语法精讲


一、变量声明

javascript

// let 块级作用域变量 let count = 0 count = 1 // ✅ 可重新赋值 if (true) { let count = 2 // ✅ 新的块级变量 } // const 常量(引用不可变) const PI = 3.14159 // PI = 3.14 // ❌ 报错 const user = { name: 'John' } user.name = 'Jane' // ✅ 可修改属性 // user = {} // ❌ 不可重新赋值

二、箭头函数

javascript

// 语法:(参数) => 返回值 const add = (a, b) => a + b // 相当于: const add = function(a, b) { return a + b } // this 绑定(无自己的this) const person = { name: 'John', sayName: function() { setTimeout(() => { console.log(this.name) // ✅ 正确:John }, 100) } }

三、模板字符串

javascript

const name = 'John' const age = 25 // 插值 const msg = `姓名:${name},年龄:${age}` // 多行 const html = ` <div> <h1>${name}</h1> </div> ` // 表达式 const result = `${1 + 2} = ${add(1, 2)}`

四、解构赋值

javascript

// 数组解构 const [a, b, ...rest] = [1, 2, 3, 4] // a=1, b=2, rest=[3,4] // 对象解构 const { name, age } = { name: 'John', age: 25 } const { name: userName } = { name: 'John' } // userName='John' // 函数参数解构 function print({ name, age }) { console.log(`${name}, ${age}`) }

五、函数增强

javascript

// 默认参数 function greet(name = 'Guest') { return `Hello, ${name}` } // 剩余参数 function sum(...numbers) { return numbers.reduce((a, b) => a + b) } sum(1, 2, 3) // 6 // 参数解构 + 默认值 function createUser({ name = 'Anon', age = 0 } = {}) { return { name, age } }

六、扩展运算符

javascript

// 数组展开 const arr1 = [1, 2] const arr2 = [...arr1, 3, 4] // [1,2,3,4] // 对象展开(浅拷贝) const obj1 = { a: 1, b: 2 } const obj2 = { ...obj1, c: 3 } // {a:1,b:2,c:3} // 数组合并 const merged = [...arr1, ...arr2] // 函数参数展开 Math.max(...[1, 2, 3]) // 相当于 Math.max(1,2,3)

七、对象简写

javascript

const name = 'John' const age = 25 // 属性简写 const user = { name, age } // 相当于 { name: name, age: age } // 方法简写 const obj = { sayHi() { // 代替 sayHi: function() {} console.log('Hi') } } // 计算属性名 const key = 'status' const obj2 = { [key]: 'active', ['get_' + key]() { return this[key] } }

八、Class 类

javascript

// 定义类 class Person { constructor(name, age) { this.name = name this.age = age } // 方法 sayHi() { return `Hi, I'm ${this.name}` } // Getter/Setter get info() { return `${this.name}, ${this.age}` } // 静态方法 static create(name) { return new Person(name, 0) } } // 继承 class Employee extends Person { constructor(name, age, title) { super(name, age) // 调用父类构造函数 this.title = title } } const john = new Person('John', 25) john.sayHi()

九、模块化

javascript

// module.js export const PI = 3.14159 export function add(a, b) { return a + b } export default class Calculator {} // app.js import Calculator, { PI, add } from './module.js' import * as Module from './module.js' // 动态导入 const module = await import('./module.js')

十、Promise 与 Async/Await

javascript

// Promise 基础 fetch(url) .then(response => response.json()) .then(data => console.log(data)) .catch(error => console.error(error)) // Promise 组合 Promise.all([promise1, promise2]) // 全部成功 Promise.race([promise1, promise2]) // 最先完成 // Async/Await(同步写法) async function getData() { try { const response = await fetch(url) const data = await response.json() return data } catch (error) { console.error(error) } }

十一、迭代器与生成器

javascript

// 迭代协议(可迭代对象) const iterable = { [Symbol.iterator]() { let i = 0 return { next() { return i < 3 ? { value: i++, done: false } : { done: true } } } } } // for...of 遍历 for (const item of iterable) { console.log(item) // 0,1,2 } // 生成器函数 function* counter() { yield 1 yield 2 yield 3 } const gen = counter() gen.next().value // 1

十二、Set 和 Map

javascript

// Set(唯一值集合) const set = new Set([1, 2, 2, 3]) // {1,2,3} set.add(4) set.has(2) // true set.size // 4 // Map(键值对集合) const map = new Map() map.set('name', 'John') map.get('name') // 'John' map.has('name') // true // WeakMap(弱引用,防止内存泄漏) const wm = new WeakMap() wm.set(obj, 'value') // 键必须是对象

十三、实用新方法

javascript

// 字符串 'hello'.includes('ell') // true 'hello'.startsWith('he') // true 'hello'.endsWith('lo') // true 'hi'.repeat(3) // 'hihihi' // 数组 [1, 2, 3].find(x => x > 1) // 2 [1, 2, 3].findIndex(x => x > 1) // 1 [1, 2, 3].fill(0) // [0,0,0] Array.from('abc') // ['a','b','c'] // 对象 Object.assign({}, {a:1}, {b:2}) // {a:1,b:2} Object.entries({a:1,b:2}) // [['a',1],['b',2]] Object.values({a:1,b:2}) // [1,2]

十四、常用模式示例

javascript

// 1. 合并对象(覆盖顺序从右到左) const config = { ...defaultConfig, ...userConfig, ...overrides } // 2. 条件对象属性 const user = { name: 'John', ...(isAdmin && { role: 'admin' }) } // 3. 异步数据获取 async function loadData() { const [user, posts] = await Promise.all([ fetchUser(), fetchPosts() ]) return { user, posts } } // 4. 数据转换 const users = [ { id: 1, name: 'John' }, { id: 2, name: 'Jane' } ] const userMap = new Map( users.map(user => [user.id, user]) ) // 5. 错误处理包装 const safeGet = async (url) => { try { const res = await fetch(url) return await res.json() } catch { return null } }

核心要点总结

  1. let/const→ 块级作用域变量

  2. 箭头函数→ 简写 + this绑定

  3. 解构→ 快速提取数据

  4. 模板字符串→ 字符串插值

  5. 扩展运算符→ 数组/对象操作

  6. Class→ 面向对象语法糖

  7. 模块化→ 代码组织

  8. Promise/Async→ 异步处理

  9. 新数据结构→ Set/Map

  10. 对象增强→ 简化对象操作

掌握这些核心语法,即可编写现代、简洁的 JavaScript 代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1220525.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据分析从“无效报表”到“决策利器”的核心技巧

在大数据时代&#xff0c;几乎所有行业都在强调“用数据说话”&#xff0c;但多数人做的数据分析&#xff0c;却陷入了“报表堆如山&#xff0c;决策用不上”的困境——熬夜做的可视化图表&#xff0c;业务部门只扫一眼&#xff1b;算出来的精准指标&#xff0c;无法落地到实际…

Sealos 私有化部署常见报错及解决方案汇总

私有化部署这事儿,表面上是技术选型,本质上是一场关于"钱往哪儿流"的博弈。今天不聊怎么解决报错,聊聊报错背后的商业逻辑。 传统私有化的钱都被谁赚走了 你买一套商业云平台的私有化方案,license 费先来…

ArcGIS Python零基础脚本开发教程---前言

文章目录 前言一、适合人群二、你将会学到三、课程简介 前言 编程入门阶段&#xff0c;不宜过度纠结于细枝末节的记忆。过早陷入语法细节&#xff0c;容易分散新手对核心逻辑和编程思维的注意力&#xff0c;且不常用的知识点也极易遗忘。实际开发并非闭卷考试&#xff0c;无需…

VSCode+WSL 解锁 Linux 开发,cpolar 让办公无边界

VSCodeWSL 的核心功能是在 Windows 系统上实现 Linux 开发环境的无缝运行&#xff0c;VSCode 提供直观的图形化编辑界面&#xff0c;支持代码高亮、插件扩展、远程连接等功能&#xff0c;WSL 则相当于在 Windows 中嵌入了 Linux 子系统&#xff0c;可直接调用 Ubuntu、Debian 等…

JUC发展、锁、AQS、CAS、Park核心解析

目录JUC发展、锁、AQS、CAS、Park核心解析1.发展脉络与核心驱动力2. 各项关键技术及其解决的问题CAS (Compare-And-Swap, 比较并交换)AQS (AbstractQueuedSynchronizer, 抽象队列同步器)Park/Unpark (LockSupport类)对…

Criteria

Criteria​ (/kraɪˈtɪər.i.ə/) is a plural noun. It refers to the principles or standards by which something is judged or decided. Think of them as the specific rules, guidelines, or requirements us…

详细介绍:传感器学习(day09):三维手势识别:人机交互的未来革命

详细介绍:传感器学习(day09):三维手势识别:人机交互的未来革命2026-01-26 19:36 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !im…

POST和GET

目录POST和GET主要区别对比✅ 使用建议💡 总结一句话 POST和GET 主要区别对比特性 GET POST数据位置 URL查询字符串(?key=value) 请求体(body)数据可见性 明文显示在URL和浏览器历史 不在URL显示,相对安全数据…

从 Rancher 迁移到 Sealos 私有化的经验

昨天帮一个老客户从 Rancher 迁到 Sealos 私有化部署,完事儿后喝茶闲聊,他问我一个有意思的问题:这次迁移,三年后会怎样? 我认真想了想,觉得这个问题值得写一写。 第一年:运维团队会"缩水" 这不是裁员…

curl命令详解

目录curl命令详解 curl命令详解 curl(Client URL)是一个功能强大的命令行工具和库,用于传输数据,支持多种协议(如 HTTP、HTTPS、FTP、SMTP 等)。它广泛应用于测试 API、下载文件、调试网络问题等场景。 curl 在 …

2026年重庆PT型锚具厂家产品口碑排行,精选定制方案全面揭晓

在2026年的重庆PT型锚具市场上,各大厂家不断提升自身的产品质量和服务水平。消费者在选择时,除了关注品牌声誉外,还需审视厂家的生产能力及定制服务。优质的厂家如四川蜀都春鹏钢材有限公司,凭借丰富的行业经验及技…

java数据结构基础-顺序表

一.顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构&#xff0c;一般情况下采用数组存储。在数组上完成数据的增删查改。 顺序表接口的实现(手动实现&#xff0c;仅为方便初学理解&#xff0c;实际开发中都用java自带的不用手写): public class SeqList {// …

技能操作不丢分?跟紧哪家模拟培训?

“为什么连最基础的操作都差点失误?” 深夜后台的一条考生留言,瞬间戳中了无数执医技能备考人的心声。 练得熟≠考得稳,缺的从来不是重复训练,而是能1:1还原考场压迫感的仿真模拟。作为深耕医考领域的小编,每天都…

医院智能柜类全国推荐?

在当今数字化医疗的大背景下,医院智能柜类产品对于提升医疗管理效率、保障医疗物资安全等方面发挥着至关重要的作用。今天就为大家全国范围内推荐医院智能柜类产品,其中术衣博士消毒科技股份有限公司(简称 “术衣博…

术衣博士智能管理系统靠谱吗?

在当今医疗行业不断发展的背景下,智能管理系统对于医疗机构的高效运营和安全保障起着至关重要的作用。术衣博士智能管理系统凭借其独特的优势,成为众多医疗机构的信赖之选。术衣博士智能管理系统助力医疗管理升级术衣…

2026执医技能模拟培训机构推荐,哪家最仿真?

“在模拟人身上练了十几次,为什么一进考场还是手抖心慌?”一位考生的深夜留言,戳中了技能备考最深的痛点——缺乏能真正还原考场压迫感的训练。 身为长期跟踪测评各类医考培训产品的教育博主,我听过太多这样的困惑…

行研 + AI 深度融合-生物医药行业分析:五度易链 AI 智能体的实现逻辑

‍生物医药产业是全球创新最活跃、发展最迅速的战略性新兴产业之一&#xff0c;核心特征是高投入、高风险、高回报、长周期。在生物医药这个知识密集、创新驱动的高精尖领域&#xff0c;我们正面临一个前所未有的矛盾&#xff1a;一边是海量数据与科研成果的指数级增长&#xf…

Hudi 客户端实现分析

08. Hudi 客户端实现分析 主题说明 Hudi 提供了三种客户端实现&#xff1a;Spark、Flink 和 Java。理解客户端实现有助于理解不同引擎下的写入机制。 客户端实现包括&#xff1a; BaseHoodieWriteClient&#xff1a;客户端基类SparkRDDWriteClient&#xff1a;Spark 客户端Hood…

被Trae IDE的solo编程模式震惊到了

AI从GPT出来就开始用&#xff0c;基本就是作为问答交互式的辅助编程工具。包括局部代码开发&#xff0c;代码优化&#xff0c;错误检擦&#xff0c;特别是在不熟悉轮子的语言上&#xff0c;会大大的减少工作量。已经经历过lua开发&#xff0c;py开发&#xff0c;本来对里边的轮…

数字员工如何依托熊猫智汇实现销售业绩的飞跃?

数字员工是一种新兴的AI销售工具&#xff0c;通过智能化的操作&#xff0c;能够有效优化企业的业务流程。借助于AI销冠系统&#xff0c;数字员工实现了自动化外呼和智能应答&#xff0c;使得企业能更加高效地与客户沟通。这种创新不仅降低了人工成本&#xff0c;还提高了工作效…