JS中数组被觉得是一种对象,慢慢的,怎么忽然感觉,JS中仅仅要能够独立出来的概念怎么都能够当成对象来解释呢?有点儿怀疑。继续学吧。先来总结一下JS中数组是怎样详细使用的。

一、创建

数组的创建在JS中和Object基本上是一样的。他能够通过newkeyword来声明,也能够通过字面量的方法来创建。JS中数组创建仅仅支持一维数组。

1、new

var box=new Array();//new keyword可省略,内部可对数组进行初始化,或者声明元素的个数,这点其他语言同样

2、字面量

var box=[]; //相同也能够进行初始化

3、注意:1、默认数组中每一个元素用‘,’分开,能够用Join()方法是用不同的分隔符对数组元素进行切割,比如:Join('|')

2、JS中数组元素能够为随意类型,甚至能够为数组。创建一个复杂类型的数组:

var box = [ {                            //第一个元素为包括name和age属性的一个对象
name: 'wyy',
age:22
},
'计算机编程',
[1, 2, 45, 6,new Object()], //字面量方法创建一个数组,内包括一个对象
25 + 34,
new Array(6,7,8) //这里为一个数组
]

二、元素赋值和调用

1、赋值

在为数组元素进行赋值时,能够直接初始化为各个元素进行赋值,但这样的方式不够灵活,假设我们想动态为数组加入元素时,这个时候须要的就是在外部直接为数组中的元素进行赋值。能够利用数组中各个元素的name为其赋值,能够利用元素下标进行赋值。

var  box=[];
box.name='wyy';
box.age=22;
alert(box['name']); //这里alert(box)直接弹出数组box的话不支持。会弹出空

或者採用数组下标的方式

var  box=[];
box[0]='wyy';
box[1]=22;
alert(box); //利用下标方式能够弹出box中的元素内容

鉴于上述两种方式的差异所以,通常赋值时,我们採用索引下标进行赋值。那么依据赋值的方式,数组在调用的时候原理也是一样的。通过元素名称和索引下标来进行调用。同一时候,这里能够用length属性来获得数组元素的个数和数组中最后一个元素的值。

三、对象和操作方法

对象方法

1、栈

push:在数组末尾加入一个元素 语法:box.push('123') 注意的是假设是alert(box.push('123'))会返回最新数组的长度

pop:移除数组末尾元素:语法 alert(box.pop())//返回移除元素的值,这里和push有差别

2、队列

push:同栈中的push方法

shift:移除最先进去的元素 语法:alert(box.shift())//打印出移除元素

unshift:为数组前端加入一个元素,并返回新数组的长度。box.unshift('123')//存在不兼容现象

3、排序

reverse:返回一个逆序排列的数组,原数组也被逆序了,说明操作的是数组的引用

sort:从小到大排序,这个函数在使用前须要对其排序规则进行声明。可正负颠倒。

操作方法:

1、concat:基于原来的数组再追加一个新的数组

2、slice()和spice()这两个方法用途非常广,參数不定,规则也不定,使用时,须要细致区分。

slice主要用于取值,但不影响原来数组的值

spice主要用于删除数组中指定的元素。比如:Box.splice(1,3)//从第一个元素開始,取3个元素,而且将原数组中这些元素删掉。同一时候也能够用来插入元素,比如:

Box.splice(1,0,'wlj','dsf')//在第一个元素后插入后面的元素

var box1= box.splice(1,0,'hello'); //这里第二个參数为0,所以没有要删除的位置,那么含义转变成在第一个位置后面插入一个元素‘hello’。

小结:这一部分的知识比較碎,没有太多原理上的知识,我们必须将学过的知识进行知网,给它一条线来串起来,就像一个固定的模式一样能够从创建使用等方面将它们联系起来,多多回想,通过样例来加深理解。

JS基础——数组总结的更多相关文章

  1. JS基础-数组的常用方法-冒泡排序

    1.数组  1.关联数组    以数字作为元素下标的数组,就是索引数组.    以字符串作为元素下标的数组,就是关联数组.  2.js的关联数组    ex:在php中       $array=[& ...

  2. js基础-数组及数据类型

    数组也是引用类型 构造函数创建数组 Object 构造函数类型(所有类型基类)   Array 构造函数类型 求幂运算符 **   2**32-1 数组容量最大 arry.length 如果减小len ...

  3. JS基础——数组API之数组操作(filter、map、some、every、sort)

    var arr = [1,2,3,4];   forEach arr.forEach((item,index,arr) => { console.log(item) //结果为1,2,3,4 } ...

  4. js基础---数组方法

    数组数据的排序及去重 sort无形参的排序方式 arr1=[2,12,3,15]; var a=arr1.sort();console.log(arr1);console.log(a);//排序会改变 ...

  5. js基础——数组的概念及其方法

    数组: 概念:是一种特殊的对象. 与普通对象的区别:a.普通对象使用字符串作为属性名,而数组使用数字作为索引来操作元素: b.数组的存储性能比普通对象好 数组的标志:[ ] 数组的索引:是从0开始的整 ...

  6. js基础----数组

    1.数组如何定义 //第一种定义方法 var arr=[1,2,3,4]; //第二种定义方法 var arr=new Array(1,2,3,4); 两者没有任何区别,[]的性能可能略高,因为代码短 ...

  7. js 基础篇(点击事件轮播图的实现)

    轮播图在以后的应用中还是比较常见的,不需要多少行代码就能实现.但是在只掌握了js基础知识的情况下,怎么来用较少的而且逻辑又简单的方法来实现呢?下面来分析下几种不同的做法: 1.利用位移的方法来实现 首 ...

  8. js 基础

    js基础知识点总结 如何在一个网站或者一个页面,去书写你的js代码:1.js的分层(功能):jquery(tool) 组件(ui) 应用(app),mvc(backboneJs)2.js的规划():避 ...

  9. js基础练习二之简易日历

    今天学到了js基础教程3,昨天的课后练习还没来的及做,这个是类似简易日历的小案例,视频还没听完,今晚继续...... 先看效果图: 其实做过前面的Tab选项卡,这个就很好理解了,通过鼠标放在不同月份月 ...

随机推荐

  1. SQL在declare声明变量

    在sql添加的声明变量. declare @local_variable data_type 你需要指定一个变量声明的类型, 能够使用set和select对变量进行赋值, 在sql语句中就能够使用@l ...

  2. poj2386Lake Counting

    题意是这种.给你一个N*M的矩形图.这个图由两个东西组成.'.'和'W', W代表这个地方有水. .代表这个地方没水. 假设一个有水的地方它的上下左右,左上,坐下.右上.右下也有水,那么 就看成它们连 ...

  3. 得到Android系统语言设置

    private int g_lag = 1; // String filename = Locale.getDefault().getLanguage(); if (filename != null) ...

  4. 修改系统环境变量 cmd命令

    详细大家对cmd的使用都有了一些简单的了解,但是困扰大家的主要的问题就是: cmd命令修改环境变量有两种方式:1. 短期内有效,在关闭dos窗口后就自动失效 2.长期有效,关闭dos窗口后还有效 下面 ...

  5. effective c++ 条款9 do not call virtual function in constructor or deconstructor

    在构造函数中不要调用virtual函数,调用了也不会有预期的效果. 举个例子 class Transaction { public: Transaction() { log(); } ; } clas ...

  6. Win7 IIS配置 applicationHost.config 错误:无法识别的特性“setProfileEnvironment” 解决方法

    Win7下配置IIS时容易出现这样的错误提示:这是百度知道上面另一个人提问的图,我的显示行号133 解决方法: 到C:\inetpub\history中找到最近一次的applicationHost.c ...

  7. android存储阵列数据SharedPreferences

    假设要数组数据(如boolean[] .int[]等)到SharedPreferences时,我们能够先将数组数据组织成json数据存储到SharedPreferences,读取时则对json数据进行 ...

  8. JAVA学习JSTL与EL

    一.基础 1.EL(Expression Language):为了使jsp写起来更加简单,提供了在Jsp中简化表达式的方法 2.JSTL:(JSP Standard Tag Library)jstl标 ...

  9. 【转】d3d的投影矩阵推导

    原帖地址:http://blog.csdn.net/popy007/article/details/4091967 上一篇文章中我们讨论了透视投影变换的原理,分析了OpenGL所使用的透视投影矩阵的生 ...

  10. Java误区: 静态代码块,当把类将被载入到自己主动运行?

    JAVA静态代码块会在类被载入时自己主动运行? 非常多Java开发人员的思想,被这个思想深深的轮奸了n遍,传播这个错误思想的博客,在网上一堆,越来越多的人被轮奸. 如:http://blog.csdn ...