首页 web前端 js教程 JavaScript数组的一些奇葩行为_javascript技巧

JavaScript数组的一些奇葩行为_javascript技巧

May 16, 2016 pm 03:18 PM
js数组

在程序语言中数组的重要性不言而喻,JavaScript中数组也是最常使用的对象之一,数组是值的有序集合,由于弱类型的原因,JavaScript中数组十分灵活、强大,不像是Java等强类型高级语言数组只能存放同一类型或其子类型元素,JavaScript在同一个数组中可以存放多种类型的元素,而且是长度也是可以动态调整的,可以随着数据增加或减少自动对数组长度做更改。

今天,复习了一下JavaScript的数组,然后,把他的一些奇葩行为总结了一下,在这里和大家share一下,如果有不对的地方,欢迎指出!

奇葩1:Array()构造器函数可以不使用new关键字进行调用:

Array()构造器使用传递给他的参数作为数组的元素,从而创建数组,一般的,我们是如下调用的:

1

2

3

var a = new Array(1, 2, "bom!");

a.length; //3

console.log(a); //[1, 2, "bom!"]

登录后复制

但是,省略掉new也是可以的,如下:

1

2

3

var a = Array(1, 2, "bom!");

a.length; //3

console.log(a); //[1, 2, "bom!"]

登录后复制

虽然,我不知道他的内部实现机制是什么,但是,猜想他的构造器函数可能是如下定义的:

1

2

3

4

5

6

function Array(args) {

//如果,this不是Array的实例的话,

//说明不是通过new调用的,则在这里再重新调用

if( !this instanceof Array) {

return new Array(args);

}//后面是正常调用时的实现代码<br />//...<br />}

登录后复制

奇葩2:当只传一个参数给构造函数时,行为莫测

如果只传一个参数,并且这个参数是一个整数,将会得到一个数组,并且length等于这个参数

1

2

3

var a = new Array(12);

console.log(a.length); //12

console.log(a); //[]

登录后复制

如果只传一个浮点数,就会报错:

1

var a = new Array(1.1); //Uncaught RangeError: Invalid array length(…)

登录后复制

传递一个字符串就会正常工作,并且该字符串作为数组的第一个元素:

1

2

3

var a = new Array("1.1");

console.log(a.length); //

console.log(a); //["1.1"]

登录后复制

但是为了避免二义性,我建议最好是是直接使用字面量的形式创建数组:

1

2

3

var a = []; //空数组

var a = [1, 1, "bom"]; //三个元素

var a = [12]; //一个元素,并且元素是12

登录后复制

奇葩3:数组的length属性可以被修改(可写)

如下,我们直接把本来是2的length改成了100,而且还修改成功了!!!

1

2

3

4

var a = [1, 2, 3, 4];

console.log(a.length); //4

a.length = 100;

console.log(a.length); //100

登录后复制

虽然length等于100,但是,元素a[4]-a[99]是不存在的,并且如果你请求他们的值的话,例如,从0到a.length做一个循环中做的话,那么会得到undefined。

接下来再看:

1

2

3

4

var a = [1, 2, 3, 4];

a.length = 100;

console.log(a[10]); //undefined

console.log(99 in a); //false

登录后复制

与下面的例子有点相似:

1

2

3

var a = [1, 2, 3, 4];

a[99] = undefined;

console.log(a.length); //100

登录后复制

不同之处在于,这里的a[99]存在了,因为我们创建了它,即使他拥有的是undefined的值。但是从a[4]到a[98]的所有元素则是不存在的,如下:

1

2

3

4

5

var a = [1, 2, 3, 4];

a[99] = undefined;

console.log(99 in a); //true;

console.log(98 in a); //false

console.log(a.length); //100

登录后复制

以上所述给大家分享了JavaScript数组的一些奇葩行为,文章写的不好还请见谅,谢谢!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

es6 数组怎么移除元素 es6 数组怎么移除元素 Jan 11, 2023 pm 03:51 PM

方法:1、用shift()删除第一个元素,语法“数组.shift()”;2、用pop()删除最后一个元素,语法“数组.pop()”;3、用splice()删除任意位置的元素,语法“数组.splice(位置,个数)”;4、用length删除尾部的N个元素,语法“数组.length=原数组长度-N”;5、直接赋予空数组“[]”来清空元素;6、用delete删除指定下标的一个元素。

javascript如何将字符串转为数组 javascript如何将字符串转为数组 Nov 23, 2022 pm 07:28 PM

3种转换方法:1、使用split(),可将给定字符串拆分为字符串数组,语法“str.split(分隔符,数组最大长度)”;2、利用扩展运算符“...”,可迭代字符串对象,将其转为字符数组,语法“[...str]”;3、使用Array.from(),可将字符串转为数组,语法“Array.from(str)”。

js数组可以转化成php数组吗 js数组可以转化成php数组吗 Jun 02, 2023 am 10:06 AM

js数组可以转化成php数组,其操作方法是:1、建立php示例文件;2、使用语法“JSON.stringify()”将js数组转化为JSON格式的字符串;3、使用语法“json_decode()”将JSON格式字符串转为PHP数组,此处添加了参数true,表示将JSON格式字符串转换成PHP关联数组。

js获取数组长度的方法 js获取数组长度的方法 Jun 20, 2023 pm 05:33 PM

在 JS 中获取数组长度非常简单,每个数组都有一个 length 属性,该属性返回数组的最大长度,即其值等于最大下标值加 1。由于数字下标必须小于 2^32-1,所以 length 属性最大值等于 2^32-1。下面代码定义了一个空数组,然后为下标等于 100 的元素赋值,则 length 属性返回 101。因此,length 属性不能体现数组元素的实际个数。

js数组删除某个元素有几种方法 js数组删除某个元素有几种方法 Aug 02, 2023 am 10:09 AM

js数组删除某个元素有4种方法,分别是:1、使用splice;2、使用filter;3、使用pop方法和shift;4、使用delete关键字。

JS数组排序:sort()方法怎么用 JS数组排序:sort()方法怎么用 Dec 27, 2023 pm 03:40 PM

JavaScript的Array.prototype.sort()方法用于对数组的元素进行排序。此方法是就地排序,也就是说,它修改原始数组,而不是返回一个新的排序数组。默认情况下,sort()方法按照字符串Unicode码点值进行排序。这意味着它主要用于字符串和数字的排序,而不是用于对象或其他复杂数据类型的排序。

js数组去重的方法有哪些 js数组去重的方法有哪些 Aug 09, 2023 pm 04:47 PM

js数组去重的方法有使用Set、使用indexOf、使用includes、使用filter和使用reduce。1、使用Set,特点是集合中的元素不会重复;2、使用indexOf,可以返回指定元素在数组中的第一个索引位置;3、使用includes,可以用来判断一个元素是否已经存在于数组中;4、使用filter,可以用来筛选元素;5、使用reduce,可以将数组中的元素压缩等等。

JavaScript怎么求数组长度和元素之和 JavaScript怎么求数组长度和元素之和 Sep 20, 2022 pm 02:11 PM

JavaScript中,可利用length属性来获取数组长度,语法“数组对象.length”;可使用reduce()或reduceRight()函数来求元素之和,语法“arr.reduce(function f(pre,curr){return pre+cur})”或“arr.reduceRight(function f(pre,curr){return pre+cur})”。

See all articles