ES5新增内容
一、数组API
实际开发中forEach和map会多一些
=>是es6语法中的arrow function
举例:
(x) => x + 6
相当于
function(x){
return x + 6;
}
undefined转成数字是NaN 判断:
arr.every():判断arr中每个元素是否都符合要求
只有每个元素都符合条件时,才返回true
只要有一个元素不符合条件,就返回false
类似&&
arr.some():判断 arr中是否包含符合要求的元素
只要有一个元素符合条件,就返回true
除非所有元素都不符合条件,才返回false
类似||
如何:
var bool = arr.every(function(val,i,arr){
val //自动获得当前元素值
i //自动获得当前元素的位置
arr //自动获得当前数组
return 条件;
})
ps:参数用不到的可以不写,
every 会用function,去每个元素执行一次,收集返回的true和false。
----------------------------------------------
例:判断数组是否全部偶数,只用一个参数
<script type="text/javascript">
var arr1 = [1,2,3,4,5];
var arr2 = [10,6,4,8,2];
var arr3 = [1,2,3,2,1];
function allEven(arr){
return arr.every(function(val){
return val%2==0;
})
//简写成:
return arr.every(val=>val%2==0); }
console.log(
allEven(arr1),//false
allEven(arr2),//true
allEven(arr3) //false
)
</script> 上述例子改成arr.some()结果为:true true true
----------------------------------------
例:判断是不是升序排序:三个参数都用到
var arr1 = [1,2,3,4,5];
var arr2 = [10,6,4,8,2];
var arr3 = [7,6,3,2,1];
function isASC(arr) {
return arr.every(function(val,i,arr){
//最后一个值和自己比较永远为true,4<4时就是最后一个值了,设true
return i<arr.length-1 ? val<=arr[i+1]:true;
})
//简写成:
return arr.every(
(val,i,arr) => i<arr.length-1?val<=arr[i+1]:true
); }
console.log(
isASC(arr1),//true
isASC(arr2),//false
isASC(arr3) //false
)
---------------------------------------------------------------------------------------------------------------- 二、遍历
arr.forEach():对原数组中每个元素执行相同的操作,不能新值返undefined
arr.map():取出原数组中的值,加工后,放入新数组,可以赋新值,返回新值
如何:arr.forEach(function(val,i,arr){
arr[i]=新值;
})
arr.map(function(val,i,arr){
return 新值;
})
例:数组arr1值乘以2,数组arr2除以2给新值
var arr1 = [1,2,3,4,5];
var arr2 = [10,6,4,8,2];
var arr3 = [7,6,3,2,1];
//每个值 *2返回
arr1.forEach(function(val,i,arr){
arr[i]*=2;
})
//简写成:
arr1.forEach((val,i,arr)=>arr[i]*=2)
console.log(String(arr1))//2,4,6,8,10 //每个值 /2返回新值,新变量接
var newArr = arr2.map(function(val,i,arr){
return val/2;
})
//简写成:
var newArr = arr2.map(val =>val/2)
console.log(String(arr2))//10,6,4,8,2
console.log(String(newArr))//5,3,2,4,1 三、过滤和汇总
过滤:选取原数组中符合条件的元素组成新数组
var subArr = arr.filter(function(val,i,arr){
return 条件;//所有返回true的元素,被复制到新数组
})
例:过滤arr1中所有偶数
var arr1 = [1,2,3,4,5];
var evens =arr1.filter(function(val){
return val%2==0;
})
//简写成:
var evens = arr1.filter(val=>val%2==0)
console.log(String(arr1))//1,2,3,4,5
console.log(String(evens))//2,4 汇总:对数据中每个元素的值最终统计出一个新结果
var result = arr.reduce(function(prev,val,i,arr){
prev //获得截止目前的统计结果
return prev+val; //当前值和现在的prev值
},start) //start是汇总后要加的值到总和中
例:汇总arr1与arr2总和
var arr1 = [1,2,3,4,5];
var arr2 = [10,6,4,8,2];
//求arr1总和
var result =arr1.reduce(function(prev,val){
return prev+val;
})
var result =arr2.reduce(function(prev,val){
return prev+val;
},result)
console.log(result)//45
//25
var result =arr1.reduce(function(prev,val){
return prev+val;
},10)
console.log(result)//25 效率:数组API,其实内部使用的还是for循环遍历的方式,并没有提高程序的执行效率。只是简化了代码量。 在鄙视面试中会提到不能用数组API,意思是舍去了for循环还考你什么 *****bind()
什么是:基于一个现有函数,创建一个新函数,并永久绑定this。
不但可永久绑定this,也可永久绑定参数
为什么:this总是发生变化。
何时:只要希望一个对象永久绑定一个函数的this上。
结果:函数中的this将永远无法被其他对象替换。
(相当于一本书写上的自己的名字) 例:定义一个计算器,没绑定bind的为公共计算器,call可以调用,绑定bind的为私人计算器,别人调用不了,
//ps:用bind绑定的call强制作借用不好用了,
function calc(base,bonus){
console.log(
this.ename+'的总工资是'+(base+bonus)
)
}
var lilei = {ename:'Li Lei'};
var hmm = {ename:"Han Meimei"};
//lilei临时借用calc计算器
calc.call(hmm,10000,4000)//Han Meimei的总工资是14000
calc.call(lilei,10000,1000)//Li Lei的总工资是11000
//lilei买了一个和 calc一样的计算器,新计算器永久属于lilei
var lilei_calc=calc.bind(lilei);
lilei_calc(10000,3000); //Li Lei的总工资是13000
lilei_calc(10000,5000); //Li Lei的总工资是15000
lilei_calc(10000,9000); //Li Lei的总工资是19000
//hmm借lilei的计算器,call没有bind强大,借来用不了,名还是Li Lei
lilei_calc.call(hmm,10000,2999);//Li Lei的总工资是12999, 鄙视题:call apply bind 区别
call和apply:临时借用一个函数,并替换this为指定对象,
-----立刻执行
bind:基于现有函数,创建一个新函数,并永久绑定this 为指定对象。
-----只创建函数,不执行(要执行在下边在调用)
何时:立刻执行函数-------call
不立刻执行 -------bind
二、Object.create()
情况1:
var o1 =Object.create({x:1,y:2}) //o1继承了属性x和y
console.log(o1.x) //1
情况2:
var o2 =Object.create(null)
console.log(o2)// 一般不这样做,没意义{}
情况3:
var o3 =Object.create(Object.prototype)
console.log(o3)// o3和{}和new Object()一样 真正意义所在第二个参数:
英意 :inherit 继承
ES5新增内容的更多相关文章
- js数组定义和方法 (包含ES5新增数组方法)
数组Array 1. 数组定义 一系列数据的集合成为数组.数组的元素可以为任何类型的数据(包括数组,函数等),每个元素之间用逗号隔开,数组格式:[1,2,3]. 2. 数组创建方式 (1) 字面量方法 ...
- AppleWatch开发教程之Watch应用对象新增内容介绍以及编写运行代码
AppleWatch开发教程之Watch应用对象新增内容介绍以及编写运行代码 添加Watch应用对象时新增内容介绍 Watch应用对象添加到创建的项目中后,会包含两个部分:Watch App 和 Wa ...
- 4日6日--ES5新增数组方法
forEach使用的函数调用,所以占内存比较大,不如定长for循环和迭代for循环 1.通过forEach将数组中的元素逐个表示出来(遍历方法,读取操作). 2.通过map将原数组中的元素进行算数运算 ...
- String方法,js中Array方法,ES5新增Array方法,以及jQuery中Array方法
相关阅读:https://blog.csdn.net/u013185654/article/details/78498393 相关阅读:https://www.cnblogs.com/huangyin ...
- 从零开始学 Web 之 HTML5(二)表单,多媒体新增内容,新增获取操作元素,自定义属性
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- Delphi XE5中的新增内容
Delphi XE5中的新增内容 Delphi XE5是所有Delphi开发人员的必须备升级,并且是来自Embarcadero的获奖的.多设备应用开发解决方案的最新版本.使用Delphi XE5的新特 ...
- ES5新增数组方法测试和字符串常见API测试
首先是ES5新增数组方法测试: <!DOCTYPE html><html lang="en"><head> <meta charset=& ...
- ES5新增的数组方法
ES5新增:(IE9级以上支持)1.forEach():遍历数组,无返回值,不改变原数组.2.map():遍历数组,返回一个新数组,不改变原数组.3.filter():过滤掉数组中不满足条件的值,返回 ...
- ES6新增内容总结
ES6新增内容有:1,模块化思想.2,关于变量let和const.3,解构赋值.4,字符串的扩展.5,函数的扩展.6,箭头函数.7,继承apply的用法 以下就是详解: 1:模块化思想 非模块化有命名 ...
随机推荐
- Apache Beam实战指南 | 手把手教你玩转KafkaIO与Flink
https://mp.weixin.qq.com/s?__biz=MzU1NDA4NjU2MA==&mid=2247492538&idx=2&sn=9a2bd9fe2d7fd6 ...
- 200行Go代码实现自己的区块链——区块生成与网络通信
go启动后,可以用telnet登录访问. 注意端口配置写在.env里面. 源码:https://github.com/mycoralhealth/blockchain-tutorial/tree/ma ...
- agc031
T1 题意:给你一个串,求所有子序列个数,满足没有相同字符.1e5,2s. 解:考虑一个合法的子序列.其中每个字母的出现位置都有(出现次数)种选择.还可以不选,要 + 1. 然后乘起来就做完了.如果变 ...
- Luogu P4551 最长异或路径
题目链接 \(Click\) \(Here\) \(01Trie\)好题裸题. 取节点\(1\)为根节点,向下扫每一个点从根节点到它路径上的异或和,我们可以得到一个\(sumx[u]\). 现在路径异 ...
- http协议中的请求方式
get:获取url传的查询字符串(action=show)表单和连接的url中传的值.容量2K左右. post:以post方式提交,获取表单和连接的url中传的值.容量8M左右. delete:删除某 ...
- CodeForces755F 贪心 + 多重背包二进制优化
https://cn.vjudge.net/problem/615831/origin 题意 n个人; 计划是每个人都拿一个礼物来送给一个除了自己之外的人; 如果一个人没有送出礼物,那么它和它送礼 ...
- Jz2440 环境安装
目录 Jz2440 环境安装 Ubuntu 设置 烧写工具 交叉编译环境 使用说明 烧写特性 title: Jz2440 环境安装 tags: linux date: 2018-09-20 22:56 ...
- kubernetes1.5.2 DNS
Cluster DNS主要包含如下几项: SkyDNS :提供DNS解析服务. Etcd :用于DNS的存储. Kube2sky :监听Kubernetes,当有新的Service创建时,将其注册到e ...
- Linux Cluster 基础之LVS调度算法与集群类型
Linux Cluster 基础之LVS调度算法与集群类型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.LB Cluster 1>.什么是LB LB 集群是 load ...
- Windows/Linux用户态监控进程启动事件方法
catalogue . windows wmi监控进程启动 . linux netlink监控进程启动 1. windows wmi监控进程启动 from threading import Threa ...