IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> ES6语法的相关学习 -> 正文阅读

[JavaScript知识库]ES6语法的相关学习

一、新增的用于声明变量的关键字。

(1)let

  • 声明的变量只在所处于的块级有效
  • 不存在变量提升在这里插入图片描述

(2)const

  • 声明的变量只在所处于的块级有效
  • 声明常量时必须赋值
  • 常量赋值后,值不能修改
    在这里插入图片描述

(3)var、let、const的区别

  • 使用 var 声明的变量,其作用域在该语句所在的函数内,且存在变量提升现象,值可更改。
  • 使用 let 声明的变量,其作用域在该语句所在的代码块内,不存在变量提升,值不可更改。
  • 使用 const 声明的变量,其作用域在该语句所在的代码块内,不存在变量提升,值不可更改。

二、解构赋值

(1)数组解构

// *基本*
const [a, b, c] = [1, 2, 3]
console.log(a, b, c) // 1 2 3
// *可嵌套*
const [d, [[e]], [f]] = [11, [[42]], [35]]
console.log(d, e, f) //  11 42 35
// *不完全解构*
const [g = 1, h] = []
console.log(g, h) // 1 undefined
// *剩余运算符*
const [i, ...j] = [323, 121, 32, 98]
console.log(i, j) // 323 [121,32,98]
// *默认值*
// const [k = 3] = [undefined]
// console.log(k) // 3
// const [k = 3] = []
// console.log(k) // 3
const [k = 3] = [1]
console.log(k) // 1
// 当解构模式有匹配结果,且匹配结果是 undefined 时,会触发默认值作为返回结果
// *字符串等*
const [o, p, q] = 'ljc'
console.log(o, p, q) // 'l' 'j' 'c'

(2)对象解构

// *基本*
const { name, age } = { name: 'ljc', age: 24 }
console.log(name, age) // 'ljc' 24
const { addr: val } = { addr: '深圳市' }
console.log(val) // '深圳市'
// *可嵌套可忽略*
// const obj = { p: ['hello', { y: 'world' }] }
// const {
//   p: [x, { y }]
// } = obj
// console.log(x, y) // 'hello' 'world'
const obj = { p: ['hello', { y: 'world' }] }
const {
  p: [x, {}]
} = obj
console.log(x) // 'hello'
// *不完全解构*
const aa = { f: [{ b: 'world' }] }
const {
  f: [{ b }, a]
} = aa
console.log(b, a) // 'world' undefined
// *剩余运算符*
const { name1, age1, ...objs } = {
  name1: 'ljc',
  age1: 24,
  addr: '深圳市',
  love: 'xlt'
}
console.log(name1) // 'ljc'
console.log(age1) // 24
console.log(objs) // {addr: '深圳市', love: 'xlt'}
// *默认值*
const { val1 = 10, val2 = 5 } = { val1: 3 }
console.log(val1, val2) // 3 5
const { a: val11 = 10, b: val22 = 10 } = { a: 99 }
console.log(val11, val22) // 99 10

三、箭头函数

  • 如果函数只有一个语句,并且该语句返回一个值,则可以去掉括号和 return 关键字:
  • 如果形参只有一个,可以省略小括号
const hello1 = () => {
  return 'Hello World!'
}
console.log(hello1())
const hello2 = () => 'Hello World!'
console.log(hello2())
const hello3 = val => 'Hello' + val
console.log(hello3(' world!'))
  • 箭头函数不绑定this关键字,箭头函数中的this,指向的是函数定义位置的上下文this
function fn() {
  console.log(this)
  return () => {
    console.log(this)
  }
}
const Fn = fn.call(obj)
Fn()

四、剩余参数

void (function(val1, ...val2) {
  console.log(val1) // 10
  console.log(val2) // [20,30]
})(10, 20, 30)

在这里插入图片描述

  • 剩余参数语法允许我们将一个不定数量的参数表示为一个数组。
  • 剩余参数和解构配合使用

五、ES6 的内置对象扩展

1、Array 的扩展方法

(1)扩展运算符可以将数组或者对象转为用逗号分隔的参数序列

const ary = [1, 2, 3]
console.log(...ary)
// 1 2 3

(2)可以使用扩展运算符进行数组的合并

const ary = [1, 2, 3]
console.log(...ary)
const ary1 = [1, 2, 3]
const ary2 = [4, 5, 6]
const ary3 = [...ary1, ...ary2]
ary1.push(...ary2)
console.log(ary3) // [1, 2, 3, 4, 5, 6]
console.log(ary1) // [1, 2, 3, 4, 5, 6]

(3)使用Array.from()方法可以使伪数组转为真正的数组

const arrLike = {
  '0': 'a',
  '1': 'b',
  '2': 'c',
  length: 3
}
// const newArr = Array.from(arrLike)
const newArr = Array.from(arrLike, item => item + item)
console.log(newArr)
  • 方法还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理后的值放入返回的数组。

(4)find()方法

  • 用于找出第一个 符合条件的数组成员,如果没有找到返回undefined
const arr = [
  {
    id: 1,
    name: 'ljc',
    age: 24
  },
  {
    id: 2,
    name: 'xlt',
    age: 23
  },
  {
    id: 3,
    name: 'lhw',
    age: 25
  }
]
const data = arr.find(item => item.id === 2)
console.log(data) // {id:2, name: 'xlt', age:23}

(5)findIndex()方法

  • 用于找出第一个符合条件的数组成员的位置,如果没有找到返回-1
const arr = [
  {
    id: 1,
    name: 'ljc',
    age: 24
  },
  {
    id: 2,
    name: 'xlt',
    age: 23
  },
  {
    id: 3,
    name: 'lhw',
    age: 25
  }
]
const data = arr.findIndex(item => item.id === 2)
console.log(data) // 1

(6)includes()方法

  • 表示某个数组是否包含给定的值,返回布尔值。
const arr = [1, 2, 3]
const data = arr.includes(2)
console.log(data) // true

2、String的扩展方法

(1)模板字符串

  • 使用反引号定义
  • 可以解析变量${name}
  • 可以换行
    const name = 'ljc'
    const say = `
    hello!
    my name is ${name}
    `
    console.log(say)

在这里插入图片描述

  • 可以调用函数
const fn = () => {
  return 'world'
}
const s = `hello ${fn()}`
console.log(s) // hello world

(2)startsWith()和endsWith()

  • startsWith():表示参数字符串是否在原字符串的开头,返回布尔值
  • endsWith():表示参数字符串是否在原字符串的尾部,返回布尔值
let s = 'hello world!'
console.log( s.startsWith('hello') ) // true
console.log( s.startsWith('wo') ) //  false
console.log( s.endsWith( '!' ) ) // true
console.log( s.endsWith( 'd' ) ) // false

(3)repeat()

  • repeat(n)方法表示将原字符串重复n次,返回一个新字符串
const s = 'hello world\n'
const newS = s.repeat(3)
console.log(newS)

在这里插入图片描述

六、Set 数据结构

ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。

  • Set函数可以接受一个数组作为参数,用来初始化
const set = new Set()
  • Set函数可以接受一个数组作为参数,用来初始化。
const set = new Set( [1,1,1,2,2,2,3,3,3,4,5,6] )
console.log(set)

在这里插入图片描述

Set数据结构的实例方法

  • add(value):添加某个值,返回 Set 结构本身
  • delete(value):删除某个值,返回一个布尔值,表示删除是否成功
  • has(value):返回一个布尔值,表示该值是否为Set的成员
  • clear():清除所有成员,没有返回值
const set = new Set()
set
  .add(1)
  .add(2)
  .add(3)
console.log(set)
const d = set.delete(1)
const h = set.has(1)
console.log(d)
console.log(h)
console.log(set)
set.clear()
console.log(set)

在这里插入图片描述

set遍历(foreach())

  • Set 结构的实例与数组一样,也拥有forEach方法,用于对每个成员执行某种操作,没有返回值。
const set = new Set()
set
  .add(1)
  .add(2)
  .add(3)

set.forEach(item => {
  console.log(item)
})
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-06 17:16:21  更:2022-06-06 17:16:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 16:44:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码