前端--深入了解es6语法

前言 :ECMAScript是 JavaScript 的标准化版本,由 ECMA 国际组织制定。ECMAScript 定义了 JavaScript 的语法、类型、语句、关键字、保留字等。

ES6 是 ECMAScript 的第个版本,于 2015 年发布,引入了许多重要的新特性,使 JavaScript 更加现代化。

变量声明:

作用域有块作用域,函数作用域,全局作用域。 其中全局作用域>函数作用域>块作用域

let和var的区别 (ES6使用let更加严谨)

一:let声明

使用 let 声明的变量仅在其定义的块(用 { } 包围的代码块)内有效。这意味着变量在块外不可访问。

javascript 复制代码
{
    let x = 10;
    console.log(x); // 输出 10
}
console.log(x); // ReferenceError: x is not defined

二:var声明

使用 var 声明的变量的作用范围是整个函数体。如果在函数外部声明,变量将是全局的。

javascript 复制代码
function myFunction() {
    var x = 10; // 函数作用域
    console.log(x); // 输出 10
}
myFunction();
console.log(x); // ReferenceError: x is not defined

三:const声明

 const:声明常量的 特点和语法 与let相同的。能改变的是变量,常量不能够改变

  1.常量不允许修改值。

  2.常量必须赋初始值。

  3.const与let相同 同样有块作用域(没有预解析,变量提升

  4.const定义的引用类型值内容可以修改。
javascript 复制代码
   const PI = 3.1415926;
   // PI=3.14; //报错,1.常量不允许修改值
   // const numA; //2.常量必须赋初始值。
   // numA= 10;
 
   const obj = { a: 1 };
   console.log(obj);
   obj.a = 20; // 不报错,没有修改到内存地址
   obj = { b: 1 };// 报错,修改内存地址了。console.log(obj);
   //如果存储的是一个数值,存的就是一个值
   //如果存储的是一个对象,存的就是一个内存地址

解构(数组,对象,字符串):

一:数组解构

解构: 左边一种结构,右边一种结构,左右一一对应

	1.完全解构

	2.不完全解构(部分解构)

	3.忽略方式解构

	4.嵌套解构

	5.剩余运算符方式解构Ig

	6.解构默认值

	7.使用场景

	场景1:使用解构方式实现两数交换

	场景2:使用函数返回值

1.完全结构:

javascript 复制代码
 [a, b] = [1, 2]; // 使用a b 赋值 1 2
 console.log(a, b); // 1 2

2.不完全解构(部分解构)

javascript 复制代码
 let [a] = [1, 2, 3];
 console.log(a); // 1
 let [b, c] = [1];   // b:1  c:undefined
 console.log(b, c);//如果解构不成功,变量值就默认等于undefined

3.忽略方式解构

javascript 复制代码
let [, , a] = [1, 2, 3];
console.log(a); // 3

4.嵌套解构

javascript 复制代码
let [a, b, [c]] = ["a", "b", ["c"]];
console.log(a, b, c);

5.剩余运算符方式解构

javascript 复制代码
let [a, ...b] = [1, 2, 3, 4, 5, 6, 7];
console.log(a, b);//a只取第一个,剩下的都赋值给b

6.解构默认值

javascript 复制代码
let [a, b = 100] = [90];
console.log(a, b);//如果设置了默认值,当没有第二个参数值时就取默认值180

场景1:使用解构方式实现两数交换

javascript 复制代码
let a = 10;
b = 20;
[a, b] = [b, a];
console.log(a, b);

场景2:使用函数返回值

javascript 复制代码
function fu() {
  return [1, 2, 3]
}
let res = fu()
console.log(res[0], res[1], res[2])

let [a, b, c] = fu()
console.log(a, b, c)

二:对象结构

数组解构和对象解构的不同:

数组解构是按照顺序一一解构

对象解构与顺序无关,根据属性名和变量名进行比较

1.完全解构

2. 部分解构

3.解构之后重命名

4.剩余运算符对象解构 - 浅指贝

5。对象默认值

6.使用场景: 场景1: 函数返回值

1.完全解构

javascript 复制代码
let obj = {
  name: 'zhangsna',
  age: 20
}
let { age, name } = obj;
console.log(name, age);

2.部分结构

javascript 复制代码
let obj = { name: 'zhangsan', age: 20 };
let { age } = obj;
console.log(age);
let { address, name } = obj;
console.l0g(address, name); // 如果没有匹配到则变量undefined

3.解构之后重命名

javascript 复制代码
let obj = { name: 'zhangsan', age: 20 };
let { name: myname, age: myage } = obj;
console.log(myname, myage);

4.剩余运算符对象解构 ---- 浅指贝

javascript 复制代码
let obj = { name: 'zhangsan', age: 20, address: '大河区' };
let { name, ...rest } = obj;
console.log(name, rest);

5.对象默认值

javascript 复制代码
let obj = { name: 'zhangsan', age: 20, address: '天河区' };
let { name, img = 'aaa.png' } = obj;
console.log(name, img);

6.使用场景: 场景1: 函数返回值

javascript 复制代码
function fn() {
  return {
    name: 'zhangsan', age: 20, address: '天河区'
  }
}
let res = fn();//之前不解构方式
console.log(res.name, res.age, res.address);//解构方式
let { name, age, address } = res;
console.log(name, agP, address);

三:字符串解构

字符串解构很简单,就是将字符解构出来赋给变量

javascript 复制代码
let str = 'ababa'
let [a, b, c, d] = str
console.log(a, b, c, d) // a b a b

let { length } = str
console.log(length) // 5

对象扩展:

1.属性和方法的简洁表达方式

2.属性如果对象属性名和接收的变量名相同可以直接用变量名作为性名方法 方法名(){)

3.0bject.assign()用于对象合井

4.0bject.is()方法 比较两个值是否严格相等

5.遍历对象的方法(键,值,键值对) 以及将对像转为map对象的方法

1.属性和方法的简洁表达方式,键值对的命名和方法的命名

javascript 复制代码
const name = "xiaoming";
let vue = {
  name,//等同于name:xiaoming
  data() {
    console.log("我是data-fn")
  }
  //等同于
  // data:function(){
  //   console.log("我是data-fn"))
  // }
}

2.动态属性名:在对象字面量中,使用方括号 [ ] 语法可以动态地计算属性名。这意味着你可以通过表达式来生成属性名。动态方法名:在对象字面量中,方法名同样可以使用动态计算的方式。

javascript 复制代码
//2.表达式方式的属性名和方法名
let obj = {
  ['my' + 'name']: 'zhangsan',
  ["say" + "Hi"]() {
    console.log("sayHi...")
  }
}

let nameobj = {}
console.log(obj);
obj.sayHi();
//后面写项目时,对象的属性可能是动态添加进去。并需要动态获取出来let nameobj{};
let arr = ["zhangsan", "lisi", "wangwu"];
//{"zhangsan1":"zhangsan","lisi2":"lisi"}
for (let i = 0; i < arr.length; i++) {
  console.log(arr[i]);
  nameobj[arr[i] + (i + 1)] = arr[i];
}
console.log(nameobj);
// lisi2: "lisi"
// wangwu3: "wangwu"
// zhangsan1: "zhangsan"

for (let i = 0; i < arr.length; i++) {
  console.log(nameobj[arr[i] + (i + 1)])
  // zhangsan
  // lisi
  // wangwu
};

3.0bject.assign()用于对象合井

javascript 复制代码
// 注意点:如果不希望更改源对象,第一个参数可以给一个{}
// 合井时如果存在相同属性,后面对象的会覆盖前面对象属性值
let a = { name: 'zhangsan', width: 100 };
let b = { age: 20, width: 200 };
let ret = Object.assign({}, a, b);
console.log(ret);
console.log(a, b);

4.0bject.is()方法 比较两个值是否严格相等

javascript 复制代码
console.log(1 == 1);//true
console.l0g("1" == 1);//true
console.log("1" === 1);//false

console.log(object.is(1, 1)); //true
console.log(object.is("1", 1));//false
console.log(Object.is({}, {}))//false

5.遍历对象的方法(键,值,键值对) 以及将对像转为map对象的方法

javascript 复制代码
let obj = {
  name: '11',
  age: 22
}

// 遍历值
console.log(Object.values(obj))
// 遍历键值对
console.log(Object.entries(obj))
// 遍历键
console.log(Object.keys(obj))

// 将对象转换成map
let map = new Map(Object.entries(obj))
console.log(map)

数组扩展:

1.扩展运算符...

解构。数组合并

2.find(callback) 查找,找出第一个符合条件的数组成员

3.findIndex(callback)

4.Array.of()

5.Array.from(obj)将对象转换为真正的数组

6.数组includes()方法

7.at()方法通过下标访问数组

1.扩展运算符... 解构。数组合并

javascript 复制代码
let arr1 = ["a", "b", "c"]
// let arr2 = arr1.concat();
let arr2 = [...arrl]
arr1.push("d")
console.log(arr1, arr2);

let arr3 = ["x", "y", "z"];
let arr4 = [...arr1, ...arr3];
console.log(arr4);

2.find(callback) 查找,找出第一个符合条件的数组成员

javascript 复制代码
let arr1 = [1, 2, 3, 4, 5, 6];
let result = arrl.find(function (item) {
  return item > 3;
}) // 1
console.log("result", result);

3.findIndex(callback)查找。找出第一个符合条件的数组成员对应的索引

javascript 复制代码
let arr1 = [1, 2, 3, 4, 5, 6];
let result = arr1.findIndex(function (item) {
  return item > 3;
})
console.log("result2", result);

4.Array.of()将一组值转换为数组 (了解)

javascript 复制代码
console.log(Array.of(1, 2, 3))
console.log(Array.of(99))

let arr = Array(5)
console.log(arr);//[empty]*5

5.Array.from(obj)将对象转换为真正的数组

javascript 复制代码
//获取到的dom对象集合并不是真正数组
//arguments 也不是真正数组
//转换条件:需要是可遍历的对象,需要有索引以及length属性
function fn() {
  console.log("arguments:", arguments);
  //arguments.forEach(function()())//报供arguments.forEach is not a function
  Array.from(arguments).forEach(function (item) {
    console.log(item);
  })
}
fn("zhangsan", "lisi")
console.log(["zhangsan"])
let obj = { 0: "zhangsan", 1: "lisi", length: 2 }
console.log(Array.from(obj));

6.数组includes()方法

javascript 复制代码
let arr = [1, 2, 34, 5, 33]
console.log(arr.includes(33))

7.at()方法通过下标访问数组

javascript 复制代码
let arr = [12, 3, 3, 2, 56, 5]

// 正数  与之前数组访问下标相同
// 负数  从后往前进行查找
console.log(arr.at(1))
console.log(arr.at(-1))  // 5

字符串扩展:

字符串新增的方法

1.includes()  判断是否包含 返回true /false

2.startswith() 判断字符串是否是在原字符串的头部 返回true / false

 3.endsWith()判断字符串是否是在原字符串的结尾返回true  / false

4.repeat() 将字符串重复n次 返回重复后的新字符事

5.padStart() padEnd() 字符串填充

6.字符替换 replace() 和 replaceAll()

7.优化代码的兼容性所以将trimleft()更新了trimstart() trimright()更新了trimend()

1.includes() 判断是否包含 返回true / false

javascript 复制代码
let str = "hello world"
console.log(str.includes(h)); // true
console.log(str.includes(yy)); // false

2.startswith() 判断字符串是否是在原字符串的头部 返回true / false

javascript 复制代码
let str = "hello world"
console.log(str.startsWith(h)); // true
console.log(str.startswith(e)); // false

3.endsWith()判断字符串是否是在原字符串的结尾返回true / false

javascript 复制代码
let str = "hello world"
console.log(str.endsWith('world')); // true
console.log(str.endsWith('hello')); // false

4.repeat() 将字符串重复n次 返回重复后的新字符事

javascript 复制代码
let str = "hello world"
console.log(str.repeat(3));//hello worldhello worldhello world

5.padStart() padEnd() 字符串填充

javascript 复制代码
let str = 'addsfsaf'
// str.padstart(目标长度,[,填充字符串])
let s = str.padStart(10)
let s1 = str.padStart(10, '2')

console.log(s1)  // 22addsfsaf

let str = 'addsfsaf'
// str.padstart(目标长度,[,填充字符串])
let s = str.padEnd(10)
let s1 = str.padEnd(10, '2')

console.log(s1) // addsfsaf22

6.字符替换 replace() 和 replaceAll()

javascript 复制代码
// 替换所有
let s = "aflsdjflsefel"
console.log(s.replaceAll('s', 'a'))
// 替换第一个
let s = "aflsdjflsefel"
console.log(s.replace('s', 'a'))

以上就是总结的全部内容,如果对你有帮助的话,欢迎三连,当然是互相三连。欢迎评论区留言。感谢。

相关推荐
Cshaosun2 分钟前
Web开发动画与性能优化
前端·javascript·网络·性能优化
就叫飞六吧6 分钟前
node高版本报错: digital envelope routines::unsupported
前端·javascript·vue.js
anyup_前端梦工厂14 分钟前
JS设计模式之职责链模式:优雅地处理请求流程
前端·javascript·设计模式·责任链模式
小七蒙恩22 分钟前
Java面试宝典-WEB学习
java·前端·面试
yaoxin52112324 分钟前
第四十章 创建安全对话 - 启用 IRIS Web 服务以支持 WS-SecureConversation
前端·python·安全
橙子家34 分钟前
nodejs 和 npm 版本对应关系
前端
惜.己39 分钟前
js操作元素的其他操作(4个案例+效果图+代码)
开发语言·前端·javascript·css·vscode·html·html5
就是蠢啊42 分钟前
CSS 布局——清除浮动 (二)
前端·css
无敌开心1 小时前
Web前端高级工程师培训:设计模式相关
前端·设计模式
qbbmnnnnnn1 小时前
【WebGis开发 - Cesium】三维可视化项目教程---图层管理基础
前端·wmts·cesium·vue3.0·webgis·3dtiles·图层管理