js高级程序设计第五章(部分整理)

2017-07-27  本文已影响32人  WMLJS

引用类型

对象是某个特定的引用类型的实例

5.1 Object类型:大多数引用类型的值都是Object的实例

alert(person["name"]);
alert(person.name);
//属性中包含会导致语法错误的字符
//或者属性名使用关键字或者保留字,可以使用方括号表示法
alert(person["first name"]);

5.2 Array对象

5.2.1 检测数组: Array.isArray()

5.2.2 转换方法

5.2.3 栈方法:(先进后出)

5.2.4 队列方法:(先进先出)

5.2.5 重排序方法

function compare(val1, val2) {
  if(val1 < val2) {
    return 1; //1则调换
  }else if(val1 > val2){
     return -1;
  }else {
    return 0;
  }
}
var arr = [0, 1, 2];
arr.sort(compare);  //[2,1,0]

5.2.6 操作方法

arr1.splice(0, 2); //删除前两项
arr1.splice(2, 0, 'red', 'green'); //从位置2开始插入'red'和'green'
arr1.splice(2, 1, 'red', 'green'); //删除当前位置2的项,后从位置2开始插入

5.2.7 位置方法(返回值在数组中的位置索引)

5.2.8 迭代方法 //以下方法都不会改变原数组每一项的值

5.2.9 缩小方法

var arr = [1, 2, 3, 4, 5];
var sum = arr.reduce((prev, cur, index, arr)=> {
  return prev + cur;
})
alert(sum);//15

5.3 Date类型

5.4 RegExp类型: js通过RegExp类型来支持正则表达式

var re1 = /\[bc\]at/i;
 alert(re1.source); //"\[bc\]at"
var re2 = new RegExp("\\[bc\\]at", "i");
alert(re2.source); //"\[bc\]at"
+ RegExp对象方法
  - RegExp.compile() 编译正则表达式
  - RegExp.exec() 检索字符串指定的值,返回找到的值,并确定其位置
  - RegExp.test() 检索字符串指定的值,返回true或者false

5.5 function类型:函数实际上是对象,函数名实际也是指向对象的指针,一个函数可能多个名字
5.5.1 没有重载
5.5.2 函数声明与函数表达式
+ 解析器会优先读取函数声明,并使其在执行任何代码前可用(可访问),二函数表达式则必须等到解析器执行到其所在代码,才会被真正解析执行

//正常运行
alert(get1(10));
function get1(num) {
  return num;
}
//产生错误
alert(get2(10));
var get2 = function(num) {
  return num;
}

5.5.3 作为值的函数: 函数可以作为参数传递
+ 若访问函数的指针而不执行的话,必须去掉函数名后面的那对圆括号
5.5.4 函数内部属性: this 和 arguments
+ arguments:主要用于保存函数参数,但还有个callee的属性,该属性是一个指针,指向拥有这个arguments对象的函数

//arguments.callee可以减少递归时和函数名的耦合
function factorial(n) {
  if (n<=1) { return 1 }
  else { return num * arguments.callee(n-1) }
}
//二者仅第二参数不同,
//此中this都为window,因为函数sum的执行环境是window
function sum(n1, n2) { return n1 + n2 }
//call
function callSum(n1, n2) {
  return sum.call(this, n1, n2)
}
//apply()
function applySum(n1, n2) {
  return sum.apply(this, arguments)
}
function applySum(n1, n2) {
  return sum.call(this, [n1, n2])
}
//bind()
window.color = 'red';
var o = {color: 'blue'};
function say() {console.log(this.o)}
var newSay = say().bind(o);
newSay(); //输出 blue 新的函数实例的执行环境(this)已经是传给bind的o

5.6 基本封装类型:每个包装类型都映射到对应的基本类型

待续

上一篇下一篇

猜你喜欢

热点阅读