JS数组定义及详解

JS数组定义及详解JS数组定义及详解一、总结一句话总结:在js中,文本下标的数组元素,不计入数组长度,以文本下标形式添加到数组,实际是以属性形式添加到数组对象中的。二、JS数组定义及详解1、什么是数组数组就是

大家好,又见面了,我是你们的朋友全栈君。

JS数组定义及详解

一、总结

一句话总结:在js中,文本下标的数组元素,不计入数组长度,以文本下标形式添加到数组,实际是以属性形式添加到数组对象中的。

 

 

 

二、JS数组定义及详解

1、什么是数组

数组就是一组数据的集合

其表现形式就是内存中的一段连续的内存地址

数组名称其实就是连续内存地址的首地址

 

2、关于js中的数组特点

数组定义时无需指定数据类型

数组定义时可以无需指定数组长度

数组可以存储任何数据类型的数据(比如说一个元素保存整型,一个元素保存字符串型,这个在JS中是可以的)

创建数组的语法:

var arr=[值1,值2,值3];                     //隐式创建

var arr=new Array(值1,值2,值3);      //直接实例化

var array=new Array(size);           //创建数组并指定长度

JS中符号含义:

()表示函数执行

[]表示语法模拟,表示模拟Array类的实例(=new Array())

{}表示语法模拟,表示模拟Object类的实例(=new Object())

//表示语法模拟(正则对象),表示模拟RegExp类的实例(=new RegExp())

 1 //方法一
 2 var arr1 = [1,3,5,7,9];
 3 document.write(arr1[2] + '<br>');
 4     
 5 //方法二
 6 var arr2 = new Array(2,4,6,8,10);
 7 document.write(arr2[3] + '<br>');
 8     
 9 //方法三
10 var arr3 = new Array(3);//固定数组长度为3
11 arr3[0] = 1;
12 arr3[1] = 2;
13 arr3[2] = 3;
14 document.write(arr3[2] + '<br>');

3、关于数组长度

数组对象.length

在js中,每一个数组对象都可以调用length属性,它表示数组对象下共有几个数组元素

示例:

1 var row = ['zhangsan','lisi','wangwu'];
2 doucument.write('共有'+row.length+'个人<br>');
3 
4 var length = row.length;//对数组进行遍历
5 for (var i=0;i<length;i++){
6 doucument.write(row[i]+'<br>');
7 }    

 

4、for…in语句

 

在js中,数组不是数据类型,数组的数据类型其实就是对象

Js中的For…..in语句可以实现对一个对象的所有属性的遍历

也可以使用for…in语句实现对一个数组的所有元素的遍历

语法:

for( var i in array ){

}

原理:数组中有几个元素,for..in语句就循环执行多少次

每次执行时,将当前数组元素的下标存放到变量i中

1 var row = ['zhangsan','lisi','wangwu','xiaoqiang'];
2 
3 for (var i in row){
4     document.write(i + ':' + row[i] + '<br>');
5 }    

 

结果:

  0:zhangsan
  1:lisi
  2:wangwu
  3:xiaoqiang

 

5、文本下标

格式:

arr[‘key’] = value;

在js中,文本下标的数组元素,不计入数组长度

以文本下标形式添加到数组,实际是以属性形式添加到数组对象中的

1 var arr = [1,2,3];
2 arr['first'] = 'zhangsan';
3 arr['second'] = 'lisi';
4 
5 document.write(arr.length + '<br>');
6 document.write(arr.first + '<br>');
7 document.write(arr.second + '<br>');

结果:

  3
  zhangsan
  lisi

遍历带有文本下标的数组:

1 var arr = [1,2,3];
2 arr['first'] = 'zhangsan';
3 arr['second'] = 'lisi';
4 
5 for(var i in arr){
6     document.write(i + ':' + arr[i] + '<br>');
7 }

结果:

  0:1
  1:2
  2:3
  first:zhangsan
  second:lisi

 

6、多维数组

 1 var arr = [
 2         [10,'zhangsan','male'],
 3         [11,'lisi','female'],
 4         [12,'wangwu','male']
 5     ];
 6 for (var i in arr){
 7     for(var j in arr[i]){
 8         document.write(arr[i][j]);
 9     }
10     document.write('<br>');
11 }

 

 

 

 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154331.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月30日 下午10:16
下一篇 2022年6月30日 下午10:16


相关推荐

  • 告别手动图像处理:n8n自动化工作流的高效实践指南

    告别手动图像处理:n8n自动化工作流的高效实践指南

    2026年3月14日
    1
  • 2025豆包电脑版AI智能体创建最新操作指南_豆包AI智能体如何创建

    2025豆包电脑版AI智能体创建最新操作指南_豆包AI智能体如何创建

    2026年3月12日
    6
  • java nio_(一) Java NIO 概述[通俗易懂]

    java nio_(一) Java NIO 概述[通俗易懂]一、阻塞IO与非阻塞IO阻塞IO:通常在进行同步I/O操作时,如果读取数据,代码会阻塞直至有可供读取的数据。同样,写入调用将会阻塞直至数据能够写入。传统的Server/Client模式会基于TPR(ThreadperRequest),服务器会为每个客户端请求建立一个线程,由该线程单独负责处理一个客户请求。这种模式带来的一个问题就是线程数量的剧增,大量的线程会增大服务器的开销。大多数的实现为了…

    2022年7月8日
    34
  • 内网IP和公网IP的区别及作用

    内网IP和公网IP的区别及作用说明:本文仅是针对网络知识懵懂人事的一篇白话解说文,并非技术探讨及进阶文章,各位看官自行甄选;本文仅以ipv4为基础。使用网络的人必然会接触IP地址,ip地址又分内网(私有)ip和公网(外网)ip地址,那么他们之间的区别是什么?为什么要分为内网和外网ip?何时使用哪种ip今天我就用大白话的形式,给大家举一个例子,希望能对各位对于ip有一个初步的了解。拿一个家庭来举例,一般你的路由器以内,就是内网,并且路由器内连接的所有设备或终端都会被分配一个内网ip;反之,路由器及以外就是外网ip,这个外网ip通常

    2022年6月9日
    40
  • pycharm配置python运行环境_C中调用Python

    pycharm配置python运行环境_C中调用Python目录前言一、系统路径说明二、环境配置1.在VS中选择ReleaseX642.菜单栏中选择:项目->属性3.生成dll答疑python程序目录下没有Numpy路径?具体代码参考博客前言本文主要讲解在Python程序中调用C(C++)程序的方法。主要思路是:在VS中配置好环境后,将C语言程序打包生成动态库文件.dll。将.dll改名成.pyd之后,装入相应路径,在pycharm中直接import即可环境:win10Pycharm(python3.6)(64位)VS2017(社区版)

    2022年8月26日
    9
  • FAE是什么?

    FAE是什么?FAE FieldApplica 售前工程师 技术支持 nbsp 主要是帮助客户使用某个公司产品 要求 FAE 对本公司的产品要十分熟悉 同时对常见的设计问题有丰富的经验 能快速的帮助客户用好本公司的产品 nbsp 通常这个职位不要求钻得很深 但必须能很好地理解客户的意图 知识面比较广 掌握客户的生产流程与项目进度 能帮客户解决问题 对自己解决不了的问题能够正确地反映给公司

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号