Js:ES6~ES11基础语法(一)

一、let变量声明以及const定义常量

let变量声明

特点:

  1. 变量不能重复声明

  2. 块级作用域

  3. 不存在变量提升

  4. 不影响作用域链

const定义常量

特点:

  1. 一定要赋初始值

  2. 一般常量使用大写(默认潜规则)

  3. 常量值不能修改

  4. 块级作用域

  5. 对于数组和对象的元素修改,不算对常量的修改,不会报错

二、变量的解构赋值

定义: ES6允许按照一定模式从数组和对象中提取值,对变量进行赋值,这被称为解构赋值.

1、数组的解构

2、对象的解构

三、模板字符串

定义: ES6引入新的声明字符串的方式

特点:

  1. 声明
复制代码
let str = `1233`;
  1. 内容中可以直接出现换行符

  2. 变量拼接使用${}

复制代码
let loveset = 'Amumu';
let out = `${lovest}是最帅的`;

四、简化对象写法

定义: ES6允许在大括号里面,直接写入变量和函数,作为对象对属性和方法

五、箭头函数

定义: ES6 允许使用箭头(=>)定义函数

特点:

  1. this是静态的,this始终指向函数声明时所在作用域下的this的值

  2. 不能作为构造函数实例化对象

  3. 不能使用arguments变量

  4. 箭头函数的简写

a、省略小括号,当形参有且只有一个的时候

b、省略花括号,当代码体语句只有一条语句的时候,此时return必须省略,而且语句的执行结果就是函数的返回值

注意:

  1. 箭头函数适合与this无关的回调,定时器,数组的方法回调

  2. 箭头函数不适合与this有关的回调,例如: 事件回调、对象的方法

javascript 复制代码
// 1.this是静态的,this始终指向函数声明时所在作用域下的this的值
function getName() {
    console.log(this.name)
}

let getName2 = () => {
    console.log(this.name)
}

window.name = '123'
const school = {
    name: 'school'
}

getName.call(school) // school
getName2.call(school) // 123

六、函数参数的默认值

定义: ES6允许函数参数赋值初始值

  1. 形参初始值,具有默认值的参数,一般位置要靠后(默认情况)

  2. 与解构赋值结合

javascript 复制代码
//ES6 允许给函数参数赋值初始值
//1. 形参初始值 具有默认值的参数,一般位置要靠后(潜规则)
function add(a,c=10,b) {
   return a + b + c;
}
let result = add(1,2);
console.log(result); // NaN

//2. 与解构赋值结合
function connect({host="127.0.0.1", username,password, port}){
    console.log(host) // test.com
    console.log(username) //root
    console.log(password) // root
    console.log(port) // 3306
}
connect({
    host: 'test.com',
    username: 'root',
    password: 'root',
    port: 3306
})

七、rest参数

定义: ES6引入rest参数,用于获取函数的实参,用来代替arguments

注意: rest参数必须放到参数最后

javascript 复制代码
// ES6 引入 rest 参数,用于获取函数的实参,用来代替 arguments
// ES5 获取实参的方式
 function date(){
     console.log(arguments); // ['白芷','阿娇','思慧']
 }
 date('白芷','阿娇','思慧');

// rest 参数
 function date(...args){
     console.log(args);// ['白芷','阿娇','思慧'] filter some every map 
 }
 date('阿娇','柏芝','思慧');

// rest 参数必须要放到参数最后
function fn(a,b,...args){
    console.log(a); // 1
    console.log(b); // 2
    console.log(args); // [3, 4, 5, 6]
}
fn(1,2,3,4,5,6);
相关推荐
whinc16 小时前
JavaScript技术周刊 2026年第18周
javascript
码海扬帆:前端探索之旅16 小时前
深度定制 uni-combox:新增功能详解与实战指南
前端·vue.js·uni-app
谷雨不太卷16 小时前
进程的状态码
java·前端·算法
打小就很皮...16 小时前
基于 Python + LangChain + RAG 的知识检索系统实战
前端·langchain·embedding·rag
jieyucx16 小时前
Go语言深度解剖:Map扩容机制全解析(增量扩容+等量扩容+渐进式迁移)
开发语言·后端·golang·map·扩容策略
whinc16 小时前
JavaScript技术周刊 2026年第17周
javascript
BJ-Giser16 小时前
Cesium 烟雾粒子特效
前端·可视化·cesium
空中海16 小时前
02 ArkTS 语言与工程规范
java·前端·spring