JS-ES5~6 内置对象扩展

40次阅读
没有评论

共计 2811 个字符,预计需要花费 8 分钟才能阅读完成。

数组(Array)扩展方法

扩展运算符(展开语法)

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

let arr = [1, 2, 3]
...arr // 1, 2, 3
console.log(...arr) // 1 2 3

扩展运算符可以应用于合并数组

// 方法一
let arr1 = [1, 2, 3]
let arr2 = [4, 5, 6]
let arr3 = [...arr1, ...arr2]
console.log(arr3) // [1, 2, 3, 4, 5]
// 方法二
arr1.push(...arr2)

将类数组(伪数组)或可遍历数组转化为真正的数组

let divs = document.getElementsByTagName("div")
divs = [...divs]

构造函数方法:Array.from()

let array = {
'0': '张三',
'1': '李四',
'2': '王五',
'length': 3
}
let newArr = Array.from(array)
console.log(newArr) // ['张三', '李四', '王五']

构造函数方法:Array.from() 还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理过后的值放入返回的数组

let array = {
'0': 1,
'1': 2,
'2': 3,
'length': 3
}
let newArr = Array.from(array, item => item * 2)
/* let newArr = Array.from(array, (item) => {
return item * 2
}) */
console.log(newArr) // [2, 4, 6]

实例方法

find 用于找出第一个符合条件的数组成员,如果没有找到返回 undefined

let arr = [
{
id: 1,
uname: '张三'
},
{
id: 2,
uname: '李四'
}
]
let target = arr.find((item, index) => item.id === 2)
/* let target = arr.find((item, index) => {
retrun item.id === 2
}) */
console.log(target) // 输出的是id值为2的对象

findIndex() 用于找出第一个符合条件的数组成员位置,如果没有找到返回 -1

let arr = [1, 5, 10, 15]
let index = arr.findIndex((value, index) => value > 9)
/* let index = arr.find((value, index) => {
retrun value > 9
}) */
console.log(index) // arr数组中10是大于9的,10的索引是2,返回的是2

includes() 表示某个数组是否包含给定的值

let arr = [1, 2, 3]
arr.includes(2) // true
let result = arr.includes(4) // false
console.log(result) // false

带回调函数的

JS-ES5~6 内置对象扩展

能修改原数组的

JS-ES5~6 内置对象扩展

不能修改原数组的

JS-ES5~6 内置对象扩展

字符串(String)扩展方法

模板字符串 使用反引号定义

    let uname = `张三`

模板字符串中可以解析变量

let uname = '张三'
let sayHi = `Hi, my name is ${uname}`
console.log(sayHi) // Hi, my name is 张三

模板字符串中可以换行

let result = {
uname: '张三',
sex: '男',
age: 18
}
let html = `<div>
<span>${result.uname}</span>
<span>${result.sex}</span>
<span>${result.age}</span>
</div>`

实例方法

startsWith()endsWith()

  • startsWith():表示参数字符串是否在原字符串的头部(是否在开头),返回布尔值
  • endsWith():表示参数字符串是否在原字符串的尾部(是否在结尾),返回布尔值
let str = 'Hello Word!'
let r1 = startsWith('Hello')
console.log(r1) // true
let r2 = endstsWith('!')
console.log(r2) // true
let r3 = startsWith('Hi')
console.log(r3) // false

repeat() 方法表示将原字符串重复n次,返回一个新字符串

let str = 'str'.repeat(3)
console.log(str) // strstrstr

Set 数据结构

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

  • Set 本身是一个构造函数,用来生成 Set 数据结构
const set = new Ste()
console.log(set.size) // 0
  • Set 函数可以接受一个数组作为参数,用来初始化
const set = new Set([1, 2, 3])
console.log(set.size) // 3

因为 Set 的成员的值都是唯一的,没有重复的值,可以做数组去重

const set = new Set(['a', 'a', 'b', 'b', 'c', 'c'])
console.log(set.size) // 3
let arr = [...set]
console.log(arr) // ['a', 'b', 'c']

Set 实例方法:

  • add(value):添加某个值,返回 Set 结构本身
  • delete(value):删除某个值,返回一个布尔值,表示删除是否成功
  • has(value):返回一个布尔值,表示该值是否为 Set 的成员
  • clear():清除所有成员,没有返回值
const set = new Set()
set.add(1).add(2).add(3) // 向Set结构中添加值
console.log(set) // Set(3)&nbsp;{1, 2, 3}
let r1 = set.deleta(2) //删除Set结构中值是2的成员
console.log(r1) // 删除成功返回true
let r2 = set.has(1) //表示Set结构中是否有1这个值
console.log(r2) // 如果有这个值返回true
set.clear() // 清除Set结构中所有的成员
console.log(set) // Set(0)&nbsp;{size: 0}

变量 Set 数据结构

  • Set 结构的实例与数组一样,也拥有 forEach 方法,用于对每个成员执行某种操作,没有返回值
let set = new Set([1, 2, 3, 4, 5])
set.forEach(value => console.log(value)) // 1 2 3 4 5
/* set.forEach((value) => {
console.log(value) // 1 2 3 4 5
})
set.forEach(function (value) {
console.log(value) // 1 2 3 4 5
}) */

正文完
 0
qiaofugui.cn
版权声明:本站原创文章,由 qiaofugui.cn 于2024-05-21发表,共计2811字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(没有评论)
验证码