函数的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了