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()) //方法一 var arr1 = [1,3,5,7,9]; document.write(arr1[2] + ‘’);
//方法二 var arr2 = new Array(2,4,6,8,10); document.write(arr2[3] + ‘’);
//方法三 var arr3 = new Array(3);//固定数组长度为3 arr3[0] = 1; arr3[1] = 2; arr3[2] = 3; document.write(arr3[2] + ‘’); 3、关于数组长度
数组对象.length
在js中,每一个数组对象都可以调用length属性,它表示数组对象下共有几个数组元素
示例: var row = [‘zhangsan’,‘lisi’,‘wangwu’]; document.write(‘共有’+row.length+‘个人’);
var length = row.length;//对数组进行遍历 for (var i=0;i<length;i++){ document.write(row[i]+’’); } 4、for…in语句
在js中,数组不是数据类型,数组的数据类型其实就是对象
Js中的For…in语句可以实现对一个对象的所有属性的遍历
也可以使用for…in语句实现对一个数组的所有元素的遍历
语法:
for( var i in array ){
}
原理:数组中有几个元素,for…in语句就循环执行多少次
每次执行时,将当前数组元素的下标存放到变量i中 var row = [‘zhangsan’,‘lisi’,‘wangwu’,‘xiaoqiang’];
for (var i in row){ document.write(i + ‘:’ + row[i] + ‘’); }
1、概念 函数就是封装了一段可以被重复执行调用的代码块。目的是让大量代码重复使用。
2、函数使用 2.1、声明函数 命名函数
// 函数构造格式 function 函数名(){ // 函数体 }
// (1)function 声明函数的关键字 全部小写 // (2)函数是做某件事,函数名一般是动词 // (3)函数不调用 自己不执行 匿名函数
var 变量名 = function(){} 2.2、函数调用 // 声明函数 function sayHi(){ console.log(‘Hi!~’) }
// 调用函数:函数名() sayHi() 3、函数的封装 函数的封装是把一个或者多个功能通过函数的方式封装起来,对外只提供一个简单的函数接口
4、函数的参数 参数的作用:在函数内部某些值不能固定,可以通过参数在调用函数时传递不同的值进去
形参:声明函数的小括号里 实参:调用函数的小括号里 // 声明函数 function 函数名(形参1,形参2…){
} // 调用函数 函数名(实参1,实参2…) 形参和实参不匹配问题
function getSum(a,b){ console.log(a+b); } // 如果实参个数和形参个数一致 getSum(1,2) // 3 正常输出结果 // 如果实参个数多于形参个数 getSum(1,2,3) // 3 会取形参的个数 // 如果实参个数小于形参的个数 getSum(1) // NaN 多余的形参定义为undefined。任意数字+undefined都不是一个数字 5、函数的返回值 5.1、return function 函数名(){ return 需要返回的结果; } 终止函数,return 后的代码不被执行
return只能返回一个值。如果返回多个值,以最后一个值为准
如果想返回多个值。可以利用数组存放值,返回数组
如果函数,有return返回return后的值;如果没有return则返回undefined
return可以退出循环,返回语句中的值,同时可以结束当前函数体内的代码
6、arguments 当我们不确定有多少个参数传递的时候,可以用arguments来获取
在JS中,arguments实际上它是当前函数的一个内置对象。
所有函数都内置了一个arguments对象,arguments对象中存储了传递的所有实参。
arguments展示形式是一个伪数组,因此可以遍历。
伪数组具有以下特点:
具有length属性 按索引方式存储数据 不具有数组的push,pop等方法 function fn(){ console.log(arguments) } fn(1,2,3)
通常来说,一段程序代码中所用到的名字并不总是有效和可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域。
作用: 提高了程序逻辑的局部性 增强了程序的可靠性 减少了名字冲突 1、JS作用域(ES6之前) 全局作用域 整个script标签 单独一个JS文件 局部作用域 函数内部 2、变量的作用域 全局变量 全局作用域下的变量,全局下都可以使用 注:函数内部没有声明,直接赋值的变量也是全局变量 局部变量 局部作用域下的变量,只能在函数内部使用 注:函数的形参也可看做局部变量 区别 从执行效率看 全局变量只有浏览器关闭的时候才会销毁,比较占内存资源 局部变量当程序执行完毕就会销毁 3、块级作用域 if{} for{}的花括号中定义的变量外部可以使用 当前JS没有块级作用域的概念 ES6新增块级作用域概念