碎片知识点

箭头函数与普通函数区别

  • 箭头函数没有自己的this,this依赖以上级;不能改变this(因为没有自己的this)。
  • 箭头函数不能new,由于(1)本身没有this,(2)没有prototype
  • 箭头函数没有arguments(类数组),但可用扩展运算符接收参数(...arg)
  • 写法更简洁
function fn(){
    console.log(this) // Window
    console.log(arguments)
}
fn(2,91,9)

// 箭头函数
let fnc = (...arg)=>{
    console.log(this) // Window
    console.log(arg)
}
fnc(8,29,100)

数组相关

改变原始数组:

shif:从数组中删除第一个元素,然后返回该元素

let arr = [1,27,89,1,9].shift() // 1

unshift:法将一个或多个项追加到数组的开头,返回数组的新长度(改变原始数组)

let arr = [1,27,89,1,9].unshift(100) // 6

pop:法从数组中删除最后一个元素,然后返回该元素

let arr = [1,27,89,1,9].shift() // 9

reverse:数组的反转顺序

let arr = [1,27,89,1,9].reverse() // [9, 1, 89, 27, 1]

sort:对数组的元素进行排序

let arr = [1,27,89,1,9].sort() // [1, 1, 27, 89, 9] 注:没按照值的大小排序

splice:从数组中删除元素,并插入新的元素

let arr = [1,27,89,1,9].splice(1,3) //[27, 89, 1]

push:将一个或多个项追加到数组的末尾,并返回新的长度

let arr = [1,27,89,1,9].push(100) //6

不改变原始数组

slice:选取数组的的一部分,并返回一个新数组

[1,27,89,1,9].slice(1,3) // [27, 89]

concat:将一个或多个数组连接到原始数组

[1,27,89,1,9].concat(1,3) // [1, 27, 89, 1, 9, 1, 3]

join:数组转换字符串

[1,27,89,1,9].join() // "1,27,89,1,9"

map:法通过在每个数组项上使用callback调用结果来创建一个新数组

[1,27,89,1,9].map(function(a){
    return a+1
})
//  [2, 28, 90, 2, 10]

filter:创建一个新数组, 其包含通过所提供函数实现的测试的所有元素

[1,27,89,1,9].filter(function(a){
    return a%3==0
})
// [27, 9]

map与forEach

let arrs = [1,8,19,29,10]
    
    arrs.forEach(function(val,index,arr){
        console.log(val,index,arr)
    })
    console.log('map----------------')

    arrs.map(function(val,index,arr){
        console.log(val,index,arr)
    })
参数一:当前数组中元素;参数二:索引; 参数三:当前数组

区别:
forEach()返回值是undefined,不可以链式调用
map()返回一个新数组,原数组不会改变
没有办法终止或者跳出forEach()循环,除非抛出异常

注意:当数组中元素是值类型,map不会改变原数组;当是引用类型,则可以改变原数组

let marr =[
        {
            name: 'aaa',
            id: 10
        },
        {
            name: 'bbb',
            id: 20
        }
    ]

    let arr1 = marr.map(function(val,index,arr){
        val.id = 1
        return val
    })
    console.log(arr1,marr)
    输出:[{"name":"aaa","id":1},{"name":"bbb","id":1}] //改变了原始数组

如果是要不改变

let arr1 = marr.map(item => (
        {
            ...item,
            id: 6
        }
    ))
    console.log(arr1, marr)
    [{"name":"aaa","id":1},{"name":"bbb","id":1}]
    [{"name":"aaa","id":10},{"name":"bbb","id":20}]

你可能感兴趣的:(javascript)