ES6 新特性 ES6使用 超实用_es6 web开发技巧

filter用于过滤掉“不合格”的元素
返回一个新数组,如果在回调函数中返回 true,那么就留下来,如果返回 false,就扔掉,因此返回的数组的长度和原数组的长度不一定一致

var arr = [1000, 5000, 20000, 3000, 10000, 800, 1500]
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:一个新数组,存储了所有返回true的元素
var newArray = arr.filter(function(element, index, array) {
  if (element > 5000) {
    return false
  } else {
    return true
  }
})
console.log(newArray) //[1000, 5000, 3000, 800, 1500]

// 箭头函数写法
var newArray = arr.filter(element => element > 5000)

some

some用于遍历数组,如果有至少一个满足条件,就返回 true,否则返回 false。同样的每一个元素都会执行一遍 function,相当于最后返回的结果进行了一个 ||运算,全为 false 才是 false

var arr = [2, 4, 6, 8, 10, 21] // 判断数组是否包含奇数
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:布尔类型的值,只要有一个回调函数返回true,就返回true
var flag = arr.some(function(element, index, array) {
  console.log(element, index, array)
  if (element % 2 == 1) {
    return true
  } else {
    return false
  }
})
console.log(flag) //true

// 箭头函数写法
var flag = arr.some(element => element % 2 == 1)

every

every用于遍历数组,只有当所有的元素返回 true,才返回 true,否则返回 false,每个元素执行完 function 返回的结果做一个 && 运算,全为 true 结果才是 true

var arr = [2, 4, 6, 8, 10, 21] //判断数组是否都是偶数
//第一个参数:element,数组的每一项元素
//第二个参数:index,数组的下标
//第三个参数:array,正在遍历的数组
//返回值:布尔类型的值,只有当所有的元素返回true,才返回true,否则返回false。
var flag = arr.every(function(element, index, array) {
  console.log(element, index, array)
  if (element % 2 == 0) {
    return true
  } else {
    return false
  }
})
console.log(flag) //false

// 箭头函数写法
var flag = arr.some(element => element % 2 == 0)

forEach: 作用:只会让每个元素执行一次函数, 没有别的功能 for 循环
map: 作用:返回一个新的数组,长度和原数组一样 新数组会保存每次 function 返回的值
filter: 作用:得到一个新数组, 保留哪些满足条件(返回 true)
some: 作用:得到布尔值 只要有函数返回 true,整体结果就是 true
every: 作用:得到布尔值,要所有的函数都返回 true,结果就是 true


ES6 常用点

变量声明
ES6 中提供了两个声明变量的关键字:const 和 let

注意:
在ES5中var function 声明的全局变量都是顶级对象(window)的属性,而ES6中声明的全局变量不属于顶级对象的属性

var age = 18
console.log(this.age)  // 18

let age = 18
console.log(this.age)  // undefined

let 使用

ES6 新增了let命令,用来声明变量。它的用法类似于var。
let 声明的变量只有在当前作用域有效
不存在变量提升
不允许重复声明
块级作用域

{
  let a = 10
  var b = 1
}

a // ReferenceError: a is not defined.
b // 1

// let 的情况
console.log(bar) // 报错ReferenceError
let bar = 2

let a = 10
let a = 1 //报错 Identifier 'a' has already been declared

for循环的计数器,就很合适使用let命令。

for (let i = 0; i < 10; i++) {
  // ...
}

console.log(i)
// ReferenceError: i is not defined

上面代码中,计数器i只在for循环体内有效,在循环体外引用就会报错。

下面的代码如果使用var,最后输出的是10。

var a = []
for (var i = 0; i < 10; i++) {
  a[i] = function() {
    console.log(i)


### 总结

阿里十分注重你对源码的理解,对你所学,所用东西的理解,对项目的理解。

![最新阿里蚂蚁金服四面(已拿offer)Java技术面经总结](https://img-blog.csdnimg.cn/img_convert/ef336fc6eeb8c79b1e96f97e168df90a.png)

![最新阿里蚂蚁金服四面(已拿offer)Java技术面经总结](https://img-blog.csdnimg.cn/img_convert/d3ac9c078e3063bbc4ddc4fe929112c8.png)



![最新阿里蚂蚁金服四面(已拿offer)Java技术面经总结](https://img-blog.csdnimg.cn/img_convert/04656be82d9b13ba32131bdc8ec55836.png)
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值