JavaScript学习要点(三)

函数的length属性用来表示函数所期望接收的参数个数

引用类型的实例方法都保存在prototype下,但prototype无法枚举,不能用for-in

函数有call()和apply(),接收两个参数,第一个参数接收运行环境,第二个参数接收参数,apply()接收的是arguments或array,call()的话需要将每个参数逐一列出

这两个方法最大的作用是能扩充函数赖以运行的作用域,同样的函数切换到不同作用域可能会有不同的结果

函数的bind()方法通过给参数来确定函数的运行环境即this

function sayColor() {
     alert(“A”);
}
var objectSayColor = sayColor.bind(o);

基本类型的方法只存在一行的时间

布尔表达式中的所有对象都会被转换为true

Number实例的toString函数可以通过传参数来决定到底转化成几进制的字符表现形式

toFixed函数按照指定的小数位数返回字符串,会自动四舍五入

toExponential函数返回e表示法字符串,参数代表小数位数

toPrecision函数依据传入的表示小数位数的参数,自动选择合适的方式转换为字符串

String类型实例有charAt方法,返回给定位置的那个字符,charCodeAt()返回那个字符的字符编码

在新一些的浏览器中也可以像数组一样用script访问

concat用于拼接字符串,可接受任意数量的参数一起拼到后面,但一般用+号

有slice substring substr方法

有indexOf和lastIndexOf方法

trim()方法消除前置及后缀空格,返回的是一个副本

有toUpperCase()和toLowerCase()方法

字符串的match方法和pattern的exec方法相同
repalce方法用于替换
localCompare方法用于比较

Math对象的属性有各种自然对数各种平方根
min和max方法
ceil方法向上舍入
floor方法向下舍入
round方法四舍五入
random方法返回0-1的随机数不包括0和1

对象包含四个描述其行为的特性
configurable 默认为true 能否用delete删除属性而重新定义属性和修改等
enumerable 默认为true 可用for-in
writable 默认为true
value 默认为undefined

var person = {}
Object.defineProperty(person,”name”,{writable: false, value: “A"})
delete person.name;
一旦configurable被改为false,就再也不能被改回来了,只能改writable这一个属性了
调用这个方法时,如果不指定,configurable enumerable writable默认值都是false
defineProperty第二个参数内还能像Swift一样定义访问器属性get 和 set
var book = {
    _year: 2004,
    edition: 1
};

Object.defineProperty(book, {
    get: function() {
        return this._year
    },
    set: function(newValue) {
        if (newValue > 2004)
            this._year = newValue;
            this.edition += newValue - 2004;
    }
});

defineProperties可用来定义多个属性

可通过构造函数创建新对象
function Person(name, age, job){
    this.name = name;
    this.age = age;
    this.job = job;
    this.sayName = function(){
        alert(this.name);
    };
}

var person1 = new Person("A", 29, "AAA");
var person2 = new Person("B", 27, "BBB");

person1和person2都保存着一个constructor属性,指向Person,这两个既是Person的实例也是Object的实例,因为所有的对象均继承自Object

最好使用原型模式
即在上例定义的this后面都加上.prototype,可让所有对象实例共享它所包含的属性和方法

Person.prototype.constructor 指向 Person

Person.prototype.isPrototypeOf(person1) //true

使用原型模式后,person1没有sayName属性,但它会继续搜索它的prototype,和person2一样找到原型的sayName属性,所以person1和person2两个对象实例共享原型所保存的属性和方法

hasOwnProperty(“name”) 可以判断属性是存在于对象实例还是原型之中

简写方法
function Person() {
}

Person.prototype = {
     name: “A”,
     age: 29,
     job: “AAA”,
     sayName: function() {
          alert(this.name)
     }
}

但这样的话Person.prototype.constructor就不指向Person了





你可能感兴趣的:(JavaScript)