关于JavaScript数组你所不知道的3件事


Posted in Javascript onAugust 24, 2016

在编程语言当中,数组(Array)是一个非常常用的功能;它是一种特殊的变量,可以用来同时储存多个数值。然而,在JavaScript方面,数组的功能还有很多其他值得探索的地方。

在这篇文章中,我们将会讨论JavaScript数组的三个并不那么常见的功能。

1. 给数组添加自定义属性

在网上搜寻有关JavaScript数组的定义时,你会发现几乎所有人对于数组的定义都一样:一种对象。

事实上,我们用JavaScript处理的所有东西,都可以视为是一种对象。JavaScript中有两种数据类型,基本类型数对象类型,但是基本类型基本都是包括在对象类型之中的。

数组、函数、Date在JavaScript中都是预定义的对象,它们内部都包含了方法、属性和各自的标准化句法。

JavaScript数组有以下三种不同的属性:

1) 数组的索引也是其属性

2) 内置属性

3) 你可以自己添加自定义属性

前两种属性是大家比较熟知的,你可能每天都在使用,但是我还是想在这里简单的多说两句,然后再来谈谈如何给数组添加自定义属性。

将索引作为属性

JavaScript数组可以使用方括号句法,例如var ary = [“orange”,”apple”,”lychee”];。

数组元素的索引基本上也是一种属性,而其属性的名称永远都是非负整数。

数组的索引元素对类似一个对象的关键值对。索引是数组对象的独特特性,与其他内置属性不同,它们可以单独通过方括号进行配置,例如 ary[3] = “peach”;。

内置属性

数组拥有内置属性,例如array.length。这个长度属性包含了一个整数值,用来表示数组的长度。

一般情况下,内置属性经常可以在数组等预先定义的JavaScript对象中找到。内置属性与内置方法联合在一起,它们可以对普通对象进行自定义,让对象满足不同的需求。

在访问内置属性的时候,你可以使用两种句法:object.key或是object[“key”]。也就是说,在获取数组长度的时候,你可以写成ary[“length”]。

为数组对象创建自定义属性

现在我们来谈一谈如何为数组添加自定义属性。数组是一种预定义对象,它在不同的索引中储存了不同的种类的值。

通 常情况下,我们没有给数组添加自定义属性的需要;也是出于这个原因,我们在刚刚学习JavaScript的时候,没有人告诉我们可以给数组添加属性。事实 上,如果你想要向对待一般对象那样,给数组添加关键值对,你也可以使用一般的对象来达到目的。但是,这并不是说完全没有特殊情况,在某些情况下,你可以利 用数组也是一种对象的事实,给它添加一个或多个自定义属性。

例如,你可以给数组添加一个可以识别元素“类型(kind)”或是“类(class)”的自定义属性。具体请参见下方实例:

var ary = ["orange","apple","lychee"];
ary.itemClass = "fruits";
console.log(ary + " are " + ary.itemClass);

请注意,你给数组所添加的自定义属性都是可数的,也就是说,它可以被for……in等循环所拣选。

2. 在数组元素中进行循环

你可能会说:“这个我早就知道了。”没错,你已经知道如何对数组元素进行索引了。但是“在数组元素中进行循环”这样的说法你可能会觉得有些抽象,因为我们真正循环的,是数组的索引。

由于数组索引都是又非负整数所构成的,因此通常情况下,我们都会从0开始,直到数组的全部长度,来对整数值进行迭代,然后使用那个迭代后的值来根据特定的索引来获取数组元素。

然而,自从ECMAScript6出现之后,我们可以不再管索引,直接在数组值中进行循环,而且这个操作可以使用for……of循环来完成。

在数组中,for……of循环可以根据索引的顺序对数组元素进行循环,换句话说,它可以掌管索引的迭代,根据给予的索引获取一个已经存在的数组值。如果你只是想要在所有数组元素中进行循环,并且使用它们,这个循环非常实用。

var ary = ["orange","apple","lychee"];
for (let item of ary){
 console.log(item);
}
For comparison, with the regular for loop, we get the indices instead of the values as output.
 

var ary = ["orange","apple","lychee"];
for (var item = 0; item < ary.length; item++){
 console.log(item);

}

3. 元素的数量不等同于其长度

一般情况下,当我们在谈到数组长度的时候,我们会认为其长度要么是数组值的数量,要么是我们手动给数组设定的长度。但是事实上,数组的长度取决于其内部最大的已经存在的索引。

长度是一个非常灵活的属性。无论你是否曾实现调整了数组的长度,只要你不断的给数组添加新的值,它的长度也会随之增长。

var ary = [];
ary.length = 3;
console.log(ary.length);
ary[5] = "abcd";
console.log(ary.length);

在上面的例子中,你可以看到我给数组的索引5只指定了一个值,之后长度变成了6。现在,如果你觉得给index 5添加一个值,数组就会自动创建索引0-4,那么你的推测就出现了错误。数组中并没有应经存在的索引0-4。你可以使用in operator来查看。

var ary = [];
ary.length = 3;
console.log(ary.length);
ary[5] = "abcd";
console.log(ary.length);
console.log(0 in ary);

上面的ary数组被我们成为稀疏数组(sparse array),这个数组的索引不会持续的被创建,而且索引之间有空气。sparse数组的对立面为密集数组(dense array)。密集数组的索引会被持续的创建,其元素的数量等于其长度。

数组的长度属性也可以用来缩短数字,确保数组中索引的最大数量永远小于数组本身,因为在默认情况下,长度的数值永远会大于索引数量的最高值。

在下面的例子中,你可以看到,我利用减少ary数组长度的方式,社区了索引5中的元素。

var ary = [];
ary.length = 3;
console.log(ary.length);
ary[5] = "abcd";
console.log(ary.length);
ary.length = 2;
console.log(ary.length);
console.log(ary[5]);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery表格拖动调整列宽效果(自己动手写的)
Sep 01 Javascript
JS组件系列之Bootstrap Icon图标选择组件
Jan 28 Javascript
微信小程序 wxapp导航 navigator详解
Oct 31 Javascript
js 单引号替换成双引号,双引号替换成单引号的实现方法
Feb 16 Javascript
js实现瀑布流效果(自动生成新的内容)
Mar 16 Javascript
微信小程序媒体组件详解(视频,音乐,图片)
Sep 19 Javascript
微信小程序五子棋游戏的悔棋实现方法【附demo源码下载】
Feb 20 Javascript
微信小程序HTTP接口请求封装的实现
Feb 21 Javascript
说说Vuex的getters属性的具体用法
Apr 15 Javascript
浅谈关于vue中scss公用的解决方案
Dec 02 Javascript
js页面加载后执行的几种方式小结
Jan 30 Javascript
Vue操作Storage本地化存储
Apr 29 Vue.js
详解Javascript ES6中的箭头函数(Arrow Functions)
Aug 24 #Javascript
手机端点击图片放大特效PhotoSwipe.js插件实现
Aug 24 #Javascript
jQuery Raty 一款不错的星级评分插件
Aug 24 #Javascript
jQuery实现自动输入email、时间和域名的方法
Aug 24 #Javascript
jQuery实现页面点击后退弹出提示框的方法
Aug 24 #Javascript
input 禁止输入特殊字符的四种实现方式
Aug 24 #Javascript
深入浅析JavaScript中的3DES
Aug 24 #Javascript
You might like
新版PHP极大的增强功能和性能
2006/10/09 PHP
php 需要掌握的东西 不做浮躁的人
2009/12/28 PHP
CI框架实现cookie登陆的方法详解
2016/05/18 PHP
基于PHPexecl类生成复杂的报表表头示例
2016/10/14 PHP
phpcms中的评论样式修改方法
2016/10/21 PHP
PHP+redis实现的悲观锁机制示例
2018/06/12 PHP
php图片裁剪函数
2018/10/31 PHP
js继承的实现代码
2010/08/05 Javascript
javascript日期转换 时间戳转日期格式
2011/11/05 Javascript
jquery ajax,ashx,json的用法总结
2014/02/12 Javascript
JavaScript在IE和FF下的兼容性问题
2014/05/19 Javascript
JavaScript中提前声明变量或函数例子
2014/11/12 Javascript
javascript结合Canvas 实现简易的圆形时钟
2015/03/11 Javascript
javascript实现控制文字大中小显示
2015/04/28 Javascript
AngularJS基础学习笔记之表达式
2015/05/10 Javascript
Jquery幻灯片特效代码分享--鼠标点击按钮时切换(1)
2015/08/15 Javascript
基于JavaScript将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
2015/12/28 Javascript
jQuery实现带延时功能的水平多级菜单效果【附demo源码下载】
2016/09/21 Javascript
jQuery获取this当前对象子元素对象的方法
2016/11/29 Javascript
Angular4 中常用的指令入门总结
2017/06/12 Javascript
基于require.js的使用(实例讲解)
2017/09/07 Javascript
JS中图片压缩的方法小结
2017/11/14 Javascript
使用classList来实现两个按钮样式的切换方法
2018/01/24 Javascript
解决vue项目本地启动时无法携带cookie的问题
2021/02/06 Vue.js
使用python和pygame绘制繁花曲线的方法
2018/02/24 Python
Python 读取WAV音频文件 画频谱的实例
2020/03/14 Python
Django使用list对单个或者多个字段求values值实例
2020/03/31 Python
解决python cv2.imread 读取中文路径的图片返回为None的问题
2020/06/02 Python
英国在线玫瑰专家:InterRose
2019/12/01 全球购物
经济管理专业毕业生推荐信
2013/11/11 职场文书
外语系毕业生找工作的求职信
2013/11/28 职场文书
元旦晚会主持词开场白
2015/05/28 职场文书
redis内存空间效率问题的深入探究
2021/05/17 Redis
Java面试题冲刺第十八天--Spring框架3
2021/08/07 面试题
mongodb数据库迁移变更的解决方案
2021/09/04 MongoDB
tomcat的catalina.out日志按自定义时间格式进行分割的操作方法
2022/04/02 Servers