js高级程序设计(第三版)总结——第五章引用类型(RegExp类和Function类)

一、RegExp类(正则类*)

1、创建正则实例
  1. var expression1 = / pattern / flags ;
    pattern:模式;
    flags:标志(g,i,m)
  2. var expression2 = new RegExp("pattern", "flags");

这两种方式在字符的转义上有很大的区别:RegExp 构造函数的模式参数是字符串,所以在某些情况下要对字符进行双重转义。所有元字符都必须双重转义,那些已经转义过的字符也是如此。例如\n(字符\在字符串中通常被转义为\,而在正则表达式字符串中就
会变成\\)!!!!!!

注意:es5中规定使用正则表达式字面量必须像直接调用RegExp 构造函数一样,每次都创建新的RegExp 实例。(意思是这两种方式已经没有区别了)

2、RegExp实例方法

(不是很懂!!!)exec():exec()接受一个参数,即要应用模式的字符串,然后返回包含第一个匹配项信息的数组;或者在没有匹配项的情况下返回null。举个例子说明一下这个方法:

var text = "mom and dad and baby";
var pattern = /mom( and dad( and baby)?)?/gi;

var matches = pattern.exec(text);
alert(matches.index); // 0
alert(matches.input); // "mom and dad and baby"
alert(matches[0]); // "mom and dad and baby"
alert(matches[1]); // " and dad and baby"
aler t(matches[2]); // " and baby"

这个例子中的模式包含两个捕获组。最内部的捕获组匹配”and baby”,而包含它的捕获组匹配”and dad”或者”and dad and baby”。数组中的第一项是匹配的第 1 个子表达式相匹配的文本,第二项包含与第一个捕获组匹配的内容,第三项包含与第二个捕获组匹配的内容。

二、Function类

1、函数的定义
  1. 函数声明
function sum (num1, num2) {
return num1 + num2;
}
  1. 函数表达式
var sum = function(num1, num2){
return num1 + num2;
};

注意1:在赋值的时候,使用函数名()是调用函数;只使用函数名,不带括号是访问函数指针。
注意2:函数声明和函数表达式的区别:解析器在向执行环境中加载数据时,会率先读取函数声明,并使其在执行任何代码之前可(可以访问);至于函数表达式,则必须等到解析器执行到它所在的代码行,才会真正被解释执行。

//可以正常执行
alert(sum(10,10));
function sum(num1, num2){
return num1 + num2;
}
//不能正常执行
alert(sum(10,10));
var sum = function(num1, num2){
return num1 + num2;
};
2、作为值的函数(*
  1. 函数作为参数
    可以像传递参数一样把一个函数传递给另一个函数;

    举个例子:

function callSomeFunction(someFunction, someArgument){
    return someFunction(someArgument);
}
function add10(num){
    return num + 10;
}
var result1 = callSomeFunction(add10, 10);
alert(result1); //20
  1. 函数作为返回值
    可以将一个函数作为另一个函数的结果返回(这个很重要,常用)。
    同样举个例子,sort()函数按照某一属性排序
function createComparisonFunction(propertyName) {
    return function(object1, object2){
    var value1 = object1[propertyName];
    var value2 = object2[propertyName];
    if (value1 < value2){
        return -1;
    } else if (value1 > value2){
        return 1;
    } else {
    return 0;
}
};
}
var data = [{name: "Zachary", age: 28}, {name: "Nicholas", age: 29}];
data.sort(createComparisonFunction("name"));
alert(data[0].name); //Nicholas
3、函数内部的属性值
  1. arguments:类数组对象,包含着传入函数中的所有参数。但这个对象还有一个名叫callee 的属性,该属性是一个指针,指向拥有这个arguments 对象的函数。
  2. this: 引用的是函数据以执行的环境对象
4、包装类型

es提供了了3 个特殊的引用类型:Boolean、Number 和String。实际上,每当读取一个基本类型值的时候,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据。

引用类型与基本包装类型的主要区别就是对象的生存期。使用new 操作符创建的引用类型的实例,在执行流离开当前作用域之前都一直保存在内存中。而自动创建的基本包装类型的对象,则只存在于一行代码的执行瞬间,然后立即被销毁。这意味着我们不能在运行时为基本类型值添加属性和方法。

举个例子:

var s1 = "some text";
s1.color = "red";
alert(s1.color); //undefined

第二行代码试图为字符串s1 添加一个color 属性。但是,当第三行代码再次访问s1 时,其color 属性不见了。问题的原因就是第二行创建的String 对象在执行第三行代码时已经被销毁了。第三行代码又创建自己的String 对象,而该对象没有color 属性。

其中String有很多的方法,使用的时候具体查询。

三、Math.random详细说一下

Math.random()方法返回大于等于0 小于1 的一个随机数。对于某些站点来说,这个方法非常实用,因为可以利用它来随机显示一些名人名言和新闻事件。

利用Math.random()从某个整数范围内随机选择一个值:

值 = Math.floor(Math.random() * 可能值的总数 + 第一个可能的值)
//1到10之间的数
var num = Math.floor(Math.random() * 10 + 1);
//2到9之间的数
var num = Math.floor(Math.random() * 9 + 2);

//通用的公式如下:
function selectFrom(lowerValue, upperValue) {
    var choices = upperValue - lowerValue + 1;
    return Math.floor(Math.random() * choices + lowerValue);
}
var num = selectFrom(2, 10);
aler t(num);

你可能感兴趣的:(web前端,js基础知识,web)