JavaScript 基础回顾——数组
JavaScript是无类型语言,数组元素可以具有任意的数据类型,同一个数组的不同元素可以具有不同类型。数组的元素设置可以包含其他数组,便于模拟创建多维数组。
1.创建数组
在JavaScript中,创建数组可以使用两种方式
(1)使用 "[]" 创建。
<script type="text/javascript">
var arr=[]; //创建空数组
var arr=['北京',0,true,'上海','代码里','www.daimali.com']; //创建带初始值的数组
</script>
(2)使用 new 关键字创建数组对象 Array()。
在JavaScript 1.1 版本之后,一般使用 new 关键字
<script type="text/javascript">
var arr=new Array(); //创建空数组
var arr=new Array('北京',0,true,'上海','代码里','www.daimali.com'); //创建带初始值的数组
</script>
2.数组元素
JavaScript中数组的元素可以是任何类型的数据。
(1)数组长度。
JavaScript数组的长度是可变的,可以通过Length属性获得。
<script type="text/javascript">
var a=new Array(); //创建空数组
var b=new Array('北京',0,true,'上海','代码里','www.daimali.com'); //创建带初始值的数组
a.Length //长度为0
b.Length //长度为6
</script>
(2)访问数组元素
JavaScript中访问数组的元素使用 [] 运算符,可以通过下标和关键字访问。遍历数组的元素可以使用循环语法或for..in语句。
<script type="text/javascript">
var arr=new Array('北京',0,true,'上海','代码里','www.daimali.com'); //创建带初始值的数组
writeln('第一个元素值为:'+arr[0]);//输出 北京
</script>
for...in
for(i in arr)
{
document.writeln('元素值为:'+arr[i]); //遍历输出数组值
}
3.多维数组
JavaScript中本来没有多维数组,但数组元素可以是任何类型的数据甚至另一个数组,可以非常方便的模拟多维数组。
(1)使用 new Array()创建多维数组
<script type="text/javascript">
var array1; var array2;
function createArr()
{
var one = new Array(3);
for(var i=0; i<one.length; i++)
{
one[i] = new Array(4);
for(var j=0;j< one[i].length; j++)
{
one[i][j] =(i+1) * (j+1);//为数组元素赋值
}
}
return one;// 返回创建的多维数组
}
</script>
(2)使用 [] 创建多维数组
array1=[ [1,2,3] , [5,8,9] , [7,'北京',8] ] //就是这么简单...
获取值得方式也简单: array1[0][1] => 1,
array1[0][2] => 2,
array1[2][1] => 北京
4.数组排序
在JavaScript中,数组可以直接使用Array对象的sort()方法,该方法允许传递一个排序函数作为参数。不过不传递参数,则按照 ASCII 字符顺序升序排序;否则,传递给该方法的函数必须返回负数,0 或正数,返回值表示相邻两个元素的比较结果,sort()方法按照比较结果排序。
<script>
var a= Array(10,215,324,3,1254,300);
a.sort(); //不传递参数 排序结果是: 10,215,324,3,1254,300
function sortfun(one, two)
{
return one - two;
}
a.sort(sortfun); //传递函数作为参数 排序结果为:3,10,215,300,324,1254
</script>
来源:代码里
链接:http://www.daimali.com/index.php/2016/04/28/335/
JavaScript 基础回顾——数组的更多相关文章
- Javascript基础回顾 之(三) 面向对象
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- Javascript基础回顾 之(二) 作用域
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- Javascript基础回顾 之(一) 类型
本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...
- JavaScript 基础回顾——对象
JavaScript是基于对象的解释性语言,全部数据都是对象.在 JavaScript 中并没有 class 的概念,但是可以通过对象和类的模拟来实现面向对象编程. 1.对象 在JavaScript中 ...
- JavaScript基础回顾一(类型、值和变量)
请看代码并思考输出结果 var scope = 'global'; function f(){ console.log(scope); var scope = 'local'; console.log ...
- javascript基础知识-数组
1.javascript创建数组时无需声明数组大小或者在数组大小变化时重新分配 2.javascript数组是无类型的 3.数组元素不一定要连续 4.针对稀疏数组,length比所有元素的索引都要大 ...
- JavaScript基础——使用数组
Array对象提供存储和处理一组其他对象的一种手段.数组可以存储数值.字符串或其他JavaScript对象.创建JavaScript数组有几种不同的方法.例如,下面的语句穿件同样的驻足的3个相同的版本 ...
- JavaScript基础回顾
1, NaN 不是数字 Infinity 无穷大 alert(parseInt("dd")); //NaN alert(1/0); //Infinity 2, 逻辑或 || ,返 ...
- JavaScript 基础(二)数组
字符串, JavaScript 字符串就是用'' 和""括起来的字符表示. 字符字面量, \n 换行, \t 制表, \b 退格, \r 回车, \f 进纸, \\ 斜杠,\' 单 ...
随机推荐
- 尝试加载 Oracle 客户端库时引发 BadImageFormatException
尝试加载 Oracle 客户端库时引发 BadImageFormatException 工程师给计算机诊断,就像医生给病人诊断一样,很多同样的症状,可能是由多种截然不同的原因导致的. 最近进行C# ...
- 无法为目标平台“Microsoft.Data.Tools.Schema.Sql.Sql120DatabaseSchemaProvider”创建扩展管理器
很久没写博客了,这段时间情绪不那么稳定,还是心态的问题... 就简单写个问题的解决方法吧,其实最近遇到的问题蛮多的,就拿这个解决过后又遇到的来写吧. 正如标题一样:VS2013 无法为目标平台“Mic ...
- [教学] Delphi Berlin 10.1 开发 Windows 10 平板 App 远程调试
Delphi Berlin 10.1 开发 Windows 10 平板 App 远程调试安装步骤: 准备电脑: 一台开发电脑,安装 Delphi 开发环境 一台平板电脑,安装 PAServer,安装方 ...
- MySQL中优化sql语句查询常用的30种方法
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使 ...
- 【转】mysql_fetch_row , mysql_fetch_array , mysql_fetch_assoc 的区别
<?php $link = mysql_connect('localhost', 'root', ”); mysql_select_db('abc', $link); $sql = “selec ...
- stm32 usart 异步传输示例
STM32F103xE的USART异步数据传输示例 USART全称Universal Synchronous/Asynchronous Receiver/Transmitter,是一种可以进行同步/异 ...
- MyBatis的resultMap
1.大家学习MyBatis时,可能会碰到实体类属性跟数据库字段不同的情况 如:数据库 ------ 实体类 stuname ----> name 即: 数据库中的stuname字段对 ...
- 利用CSS3中transparent实现三角形及三角形组合图
??如何绘制三角形及三角形的组合图案,以下是自己画的草图 源码如下 <!DOCTYPE html> <html lang="en"> <head> ...
- 鼠标滑过图片变暗文字链接滑出jQuery特效
效果体验:http://hovertree.com/texiao/jquery/7.htm HTML文件代码: <!DOCTYPE html> <html xmlns="h ...
- CyclicBarrier ------仿真赛马游戏
import java.util.ArrayList;import java.util.List;import java.util.Random;import java.util.concurrent ...