JavaScript
- 属性类型
- 创建对象
- 工厂模式
- 构造函数模式
- 原型模式
- 组合构造函数和原型模式
- 动态构造函数模式
- 寄生构造函数模式
- 问题构造函数模式
JavaScript 属性
JavaScript 创建对象
工厂模式
1 2 3 4 5 6 7 8 9 10
| function createPerson (name, age, job) { var o = new Object() o.name = name; o.age = age; o.job = job; o.sayName = function () { console.info(this.name) }; return o }
|
构造函数模式
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| function Person (name, age, job) { this.name = name; this.age = age; this.job = job; this.sayName = function () { console.info(this.name) } }
var person1 = new Person('Nicholas', 29, 'Software Engineer')
person1.constructor == Person person1 instanceof Person person1 instanceof Object
|
要创建Person的新实例,必须使用new操作符.实际上经历了:
- 创建一个对象
- 将构造函数的作用于赋值给新对象
- 执行构造函数中的代码
- 返回新对象
构造函数与其他函数的唯一区别,就在于调用方式不同。任何函数,只要通过new操作符来调用,那他就可以作为构造函数
1 2 3 4 5 6 7 8 9 10
| var person = new Person("",22,"")
Person("a",2,"c")
var o = new Object(); Person.call(o, "Kristen",25,"Nurse") o.sayName()
|
构造函数的不同实例中的同名方法是不相等的
1 2 3 4 5 6 7 8 9
| function Person (name, age, job) { this.name = name; this.age = age; this.job = job; this.syaName = new Function("console.info(thisname)") }
|
可以通过将方法定义在构造函数外部解决,但是也会引发新的问题,构造函数失去了封装性
1 2 3 4 5 6 7 8 9 10
| function Person (name, age, job) { this.name = name; this.age = age; this.job = job; this.syaName = sayName }
function sayName() { console.info(this.name) }
|
原型模式
1 2 3 4 5 6 7 8 9 10 11
| function Person() {}
Person.prototype.name = "Namea" Person.prototype.age = 29 Person.prototype.job = "Software Engineer" Person.prototype.sayName = function () { console.info(this.name) }
var person1 = new Person() var person2 = new Person()
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
| function Persone() {
}
Person.prototype = { name : "ada", age : 29, job : "Software Engineer", sayName: function () { console.info(this.name) } }
var frient = new Person() friend.constructor == Person
Person.prototype = { constructor: Person, name : "ada", age : 29, job : "Software Engineer", sayName: function () { console.info(this.name) } }
Person.prototype = { name : "ada", age : 29, job : "Software Engineer", sayName: function () { console.info(this.name) } }
Object.defineProperty(Person.prototype, "constructor", { enumerable: false, value: Person })
|
原型的动态性
先创建实例,再重写原型则会导致error
原生对象原型
1 2 3 4 5 6
| String.prototype.startsWith = function (text) { return this.indexOf(teext) == 0; }
var msg = "hello world" msg.startsWith("hello")
|
原型对象问题
当涉及到原型中的属性是引用类型的属性时,会产生问题。
组合使用构造函数模式和原型模式
- 构造函数用于定义实例属性
- 原型模式用于定义方法和共享的属性
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| function Person (name, age, job) { this.name = name this.age = age this.job = job this.friends = ["Shelby","Court"] }
Person.prototype = { constructor : Person, sayName: function () { console.info(this.name) } }
|
动态原型模式
1 2 3 4 5 6 7 8 9 10 11 12
| function Person(name, age, job) {
this.name = name this.age = age this.job = job
if (typeof this.sayName != 'function') { Person.prototype.sayName = funciton () { console.info(this.name) } } }
|
寄生构造函数模式
1 2 3 4 5 6 7 8 9 10
| function Person(name, age, job) { var o = new Object() o.name = name o.age = age o.job = job o.sayName = funciton () { console.info(this.name) } return o }
|
稳妥构造函数模式
稳妥对象
- 没有公共属性
- 其方法也不引用this的对象
1 2 3 4 5 6 7 8 9 10
| function Person() { var o = new Object()
o.sayName = function () { alert(name) }
return o }
|
总结自 JavaScript高级程序设计