《JavaScript权威指南》学习笔记 第四天 数组
昨天学习了js的对象,了解了js的原型链。在js里面万事万物皆对象,只不过一些原始类型要经过包装对象的包装才能暂时变为对象。数组的本质是什么呢?数组其实就是一组数,也就是链表。每个数只是这个链表上的一个位置。js的对象属性值可以是字符串,但是js的数组对象的属性值只能是数字。经常称为索引(index)。在使用的时候可以把数组当成对象来使用。
1、创建数组的方式
正如茴香豆的茴有六种写法,我们的js对象也有三种的创建方式。如果你看过昨天的博客就会,了解到创建对象的三种方式。
对象直接量
<script>
var arr = ['jack','rose','suse'];
<script>
使用包装对象
<script>
var arr = new Array('jack','rose','suse');
</script>
使用对象原型创建
<script>
var arr = Array.create()
</script>
2、稀疏数组与稠密数组
- 稀疏数组
稀疏数组就是指数组的索引(index),稀疏数组的索引并不是连续的,而是跳跃的,形如下面的代码。
<script>
var test = ['name',,'jack','suse'];
console.dir(test);
</script>
稠密数组
就是数组的索引是连续的,实际上我们平时使用的数组差不多都是稠密数组,在数组的使用上与稀疏数组并没有什么分别。
3、数组的遍历
数组的遍历还是使用for循环的比较多一点。我之前还使用过for in循环,不过for in循环用在对象里面更多一点。
4、数组的方法
- push
- unshift
- pop
- shift
- join
- reverse
- sort
- concat
- slice
- splice
- toString
- map
- filter
- every
- some
- reduce
以下为上面数组方法的例子,有兴趣的可以对照着看一下,最好是自己坐下demo,才能记得住。
<script>
//push 用来在数组尾部最后一位插入元素
var arr = ['rover','jack','rose','suse'];
arr.push('javascript');
console.dir(arr);
//unshift 在数组的头部插入一个元素
arr.unshift('first');
console.dir(arr);
//shift 删除数组头部的第一个元素。
arr.shift();
console.dir(arr);
//pop 删除数组尾部的最后一个元素
arr.pop();
console.dir(arr);
//reverse 返回一个逆序的数组。
//reverse并不返回一个新的数组,而是直接在原数组上修改。
var arrReverse = [1,2,3,4,5,6];
arrReverse.reverse();
console.dir(arrReverse);
//sort 排序函数
//当sort没有参数的时候,默认是按照英文字母来排序的。
//如果数组里面是一组数,则需要传入排序的函数。
var str = ['cup','apple','dog','banana'];
str.sort();
console.dir(str);
var num = [45.6,13.99,47.66,32,99,77]; //这里会先把数字转换成字母表顺序。
num.sort(function(a,b){
return a-b
});
console.dir(num);
//join 把数组切割成字符串,
var res = str.join('|');
console.dir(res);
//concat 相当于php里面array_merge函数了,拼合两个数组。
//不能去重,有点麻烦。
var arr1 = ['apple','banana'];
var arr2 = ['cat','dog'];
res = arr1.concat(arr2);
console.dir(res);
res.concat(['dog','fly']);
res.concat(['dog','fly']);
console.dir(res);
//slice 不包括最后一位。
var tmparr = ['apple','banana','cat','dog'];
res = tmparr.slice(0,1);
console.dir(res);
res = tmparr.slice(0,2);
console.dir(res);
console.dir(tmparr);
//splice
var sparr = ['apple','banana','cat','dog','eyy','fly','guy'];
msg = sparr.splice(1);
console.dir(msg);
console.dir(sparr);
//从以上两个打印的信息来看,splice是会在原来的数组进行处理的,会截取原数组的值。
//如果只有一个参数,则是从数组的该索引处开始往后截取。
var sparr1 = ['apple','banana','cat','dog','eyy','fly','guy'];
//第一个参数为从索引为1处开始截取,第二个参数为一共截取几个。
msg = sparr1.splice(1,2); //
console.dir(msg);
var sparr2 = ['apple','banana','cat','dog','eyy','fly','guy'];
msg = sparr2.splice(1,2,'香蕉','猫猫');
console.dir(msg);
console.dir(sparr2); //如果有第三个参数,则后续的参数为插入参数
//map 这个会对数组中的每一个值应用函数。
var marr = [1,2,3,4];
msg = marr.map(function(a){return a+1;});
console.dir(marr);
console.dir(msg);
//every 只有数组中所有的元素都满足条件,才返回true
var earr = [1,2,3,4];
msg = earr.every(
function(a){
return a > 3;
});
console.dir(msg);
//some 只要数组中有元素能满足条件就返回true
var somearr = [1,2,3,4];
msg = somearr.some(function(a){
return a > 3;
});
console.dir(msg);
//reduce 使用指定的函数将数组元素折叠
var rarr = [1,2,3,4];
msg = rarr.reduce(function(x,y){
return x+y;
});
console.dir(msg);
var rarr1 = [1,2,3,4];
msg = rarr1.reduce(function(x,y){
return (x>y)?x:y;
})
console.dir(msg);
</script>
5、数组判断
用这个方法还是比较准确的。
<script>
msg1 = Array.isArray([1,2]);
msg2 = Array.isArray({name:'jack'});
console.dir(msg1);
console.dir(msg2);
</script>
《JavaScript权威指南》学习笔记 第四天 数组的更多相关文章
- 读《JavaScript权威指南》笔记(四)--数组、函数
一.数组 1.数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引.JavaScript数组是无类型的:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有 ...
- JavaScript 权威指南-学习笔记(一)
本文所有教程及源码.软件仅为技术研究.不涉及计算机信息系统功能的删除.修改.增加.干扰,更不会影响计算机信息系统的正常运行.不得将代码用于非法用途,如侵立删! ## JavaScript 权威指南-学 ...
- JavaScript权威指南学习笔记6
这两天主要翻看了书中的第18-22章,重点看了第17章:事件化处理,其它几章节主要是翻了下书知道有相关的概念,没有真正理解其中的内容,或者没有考虑究竟如何能把里面的内容应用到实际的项目中.说的讽刺一点 ...
- JavaScript权威指南学习笔记4
今天看了第9.10.11章,感觉收获最大还是正则表达式那章节,不过这些不用太多脑子思考,问题用到了直接查书就可以了,下面分别总结一下: 第9章类和模块:分9节,前面8节都是在讲类相关的知识,最后一节讲 ...
- Javascript权威指南学习笔记
第二章:词法结构 ;function a(){alert(2)};//前面的分号保证正确地语句解析 第三章:类型.值和变量 基本概念: 1.数据类型---能够表示并操作的值的类型叫做数据类型. 2.变 ...
- javascript权威指南学习笔记3
今天看到第四章,记录一下其中的几个点,俗话说:好记性不如烂笔头嘛. 4.9 in运算符和instanceof运算符 in运算符希望它的左操作数是一个字符串或可以转化为字符串,希望它的右操作数是一个 ...
- javascript权威指南学习笔记1
打开这本书,进入到javascript的世界.以前都是看各种视频,感觉什么收获也没有,反而弄得脑袋混乱,希望能够按照这本书的节奏掌握javascript这门语言,为我的前端学习打下基础. 学习前准备: ...
- javascript权威指南学习笔记2
Javascript语言核心(2~12章) 第三章:类型.值.变量 1.数字: overflow(Infinity, -Infinity).underflow(+0,-0) 非数字值:它和任何值都不相 ...
- JavaScript权威指南学习笔记5
下午在杭图回去前看了书中第二部分的13-17章,看的很粗,感觉大部分东西自己已经知道或者平时开发中不会用到,很多章节只是简单的翻了一下,没有仔细思考里面说到的道理,下面对各章节简单的记录下. 第13章 ...
- js权威指南学习笔记(四)对象
1.创建对象 (1).通过对象直接量的方式创建 说明:对象直接量是由若干名/值对组成的映射表,名/值对中间用冒号分隔,名/值对之间用逗号分隔,整个映射表用花括号括起来. 如: 5 5 ...
随机推荐
- 设置svg图片大小
background-image: url(/resources/img/liveSupport/tx_1.svg); background-size: 16px 16px; width: 16px; ...
- 分享:关于之前锤子手机刷MIUI之后,现在有事跌宕起伏的刷回了Smartisan OS!
序言: 距离上次把锤子手机刷成MIUI之后已经一个半月了,我是一个刷机党,一个半月足够让我适应一个系统,了解一个系统.刷机有风险,不过我愿意冒这个风险,因为兴趣,没别的.刷机之后,肯定是有问题的,没 ...
- 基于DDD的.NET开发框架 - ABP模块设计
返回ABP系列 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应 ...
- [Codevs1403]新三国争霸(MST+DP)
题目:http://codevs.cn/problem/1403/ 分析: 很容易想到对于某个确定的一天,就是求个最小生成树,又因为数据范围很小,所以可以暴力.但问题的关键是如果相邻两天的方案不同,就 ...
- 使用 Eclipse 调试 Java 程序的技巧
你应该看过一些如<关于调试的N件事>这类很流行的帖子 .假设我每天花费1小时在调试我的应用程序上的话,那累积起来的话也是很大量的时间.由于这个原因,用这些时间来重视并了解所有使我们调试更方 ...
- URL参数GB2312和UTF-8编码 自动识别
网上找的,以备后用. 直接上代码: public static string QueryStringDecode(string key) { HttpRequest Request = System. ...
- C#(winform)为button添加背景图片
1.既然是添加背景图片 所以这里应该使用 Button.BackgroudImage = "" ;来设置图片 而不应该使用 Button.Image = "" ...
- FastFDFS_Jave客户端调用(亲测可用)
一.配置文件(fdfs_client.properties) 1 2 3 4 5 6 7 8 9 10 connect_timeout = 30 network_timeout = 60 charse ...
- ES6新特性:增加新类型:Symbol
本文所有Demo的运行环境都为nodeJS, 参考:让nodeJS支持ES6的词法----babel的安装和使用 : ES6新增了一种数据类型:Symbol,Symbol是用来定义对象的唯一属性名的不 ...
- splay HYSBZ1588
n天 n个营业额; sum(min(abs(wi-前面))); splay维护一下就可以 #include<stdio.h> #include<algorithm> #incl ...