数据类型检测 4种方式
1:typeof 主要检测基本数据类型 不能具体检测出引用数据类型
2:constructor --> ary.constructor --> 当前对象具体属于那个类
3:instanceof --> ary instanceof Array --> 某个对象是否属于某个类 返回布尔值
4:Object.prototype.toString.call() --> 打印对象详细信息
函数
- 函数由两部分构成
- 定义
function 函数名(){
}
- 调用 :函数名()
- 函数只定义不调用 什么也不会发生
函数定义3步骤
1、开辟了一个内存空间
2、把函数体内所有JS代码作为字符串存在内存空间中
3、把内存空间名赋值给变量名
函数调用2步骤:
1、形成私有作用域
2、把内存中的字符串 作为JS代码执行
函数返回值
- 返回值:return
- 什么情况 出现 undefined
- 没写return
- 写了return 但没写返回值
- 声明变量 但没有赋值
- 定义形参 但没有传值 拿到的是 undefined
- 对象的某个属性不存在的时候,我们拿到的值就是undefined;
参数
- 实参 形参
- 形参 函数定义阶段
- 实参 函数调用阶段
- 定义形参 但没有传实参 拿到的是undefined
- arguments.callee:拿到的是当前函数本身
- 函数 分 实名函数 和 匿名函数
- 匿名函数 给元素某个属性绑定函数表达式
- 匿名函数 (自执行函数)函数自己调用自己
闭包:
- 当函数被调用时,会形成私有作用域,保护里面的变量不受外界的干扰,函数的这种保护机制,叫做闭包
- 子函数可以使用父函数的私有变量
数组常用的方法
增加,删除和替换
- 给末尾增加 push()
- 功能:给数组末尾增加一个或多个
- 参数:有
- 返回值:数组的长度
- 原始数组是否改变:是
- 从末尾删除 pop()
- 功能:删除数组最后一个
- 参数:无
- 返回值:被删除的内容
- 原始数组是否改变:是
- 给开头增加 unshift()
- 功能:给数组开头增加一个或多个
- 参数:有,一个或多个
- 返回值:数组的长度
- 原始数组是否改变:是
- 从开头删除 shift()
- 功能:从数组开头删除一项
- 参数:无
- 返回值:被删除的内容
- 原始数组是否改变:是
- 操作数组的任何位置,进行增加,删除,替换 splice
-
删除
- 一个参数,从当前索引,一直删完
- 两个参数,splice(2,3)
- 从索引2开始,删除3个
- 被删除的内容以一个新数组的形式返回
-
增加
- 三个参数 ary.splice(2,0,'aa','bb')
- 从索引2开始,增加'aa' 'bb'
- 增加的内容插入到索引2的前面
- 第二项参数为0
- 返回值:无
- 原始数组是否改变:是
- 三个参数 ary.splice(2,0,'aa','bb')
-
替换
- 三个参数 ary.splice(2,2,'aa','bb')
- 返回值:被删除的内容,以一个新数组的形式返回;
- 原始数组是否改变:是
-
数组克隆和拼接
- slice(n,m) 从索引n克隆到索引m,不包括索引m,[n,m)包前不包后;
- 原数组不变
- 克隆 ary.slice(0) / ary.slice()
- concat 拼接
- ary1.concat(ary2,ary3);
- 克隆 ary.concat() 不要传参;
数组的翻转和排序
- 数组的翻转 reverse()
- 返回值:就是翻转后的新数组
- 原数组发生改变;
- 数组的排序 sort()
ary.sort(function(n,m){
return n-m; //从小到大排
//return m-m //从大到小排
})
数组转字符串
- ary.toString() 把数组转成以逗号分割的字符串;
- ary.join('拼接形式')
- 配合eval()可以实现数学运算
数组常用但不兼容的方法
- ary.indexOf() 查找数组中是否有某项,如果有返回对应内容的索引,如果没有返回-1;
- ary.forEach()
- forEach接收两个参数,一个callback,一个thisArg
- callback接收三个参数:1)item 2)index 3)input
- thisArg用来改变callback中的this指向;
- forEach 没有返回值,但是map有返回值
- ary.map()