1.工厂模式
function createBlog(name, url) {
var o = new Object();
o.name = name;
o.url = url;
o.sayUrl= function() {
alert(this.url);
}
return o;
}
var blog1 = createBlog('wuyuchang', 'http://www.jb51.net/');
alert(blog1);
2.构造函数模式
function Blog(name, url) { this.name = name; this.url = url; this.alertUrl = function() { alert(this.url); }} var blog = new Blog('wuyuchang', 'http://www.jb51.net/');alert(blog instanceof Blog);
3.原型模式
function CreateJsPerson(name, age) { this.name = name; this.age = age;}CreateJsPerson.prototype.writeJs = function () { console.log(this.name + ' write js');};var p1 = new CreateJsPerson('iceman' , 25);var p2 = new CreateJsPerson('mengzhe' , 27); console.log(p1.writeJs === p2.writeJs);
4.混合构造函数和原型模式
function Blog(name, url, friend) { this.name = name; this.url = url; this.friend = friend;}Blog.prototype.alertInfo = function() { alert(this.name + this.url + this.friend);}var blog = new Blog('wuyuchang', 'http://tools.jb51.net/', ['fr1', 'fr2', 'fr3']), blog2 = new Blog('wyc', 'http://**.com', ['a', 'b']);blog.friend.pop();blog.alertInfo(); blog2.alertInfo();
5.动态原型模式
function Blog(name, url) { this.name = name; this.url = url; if (typeof this.alertInfo != 'function') { // 这段代码只执行了一次 alert('exe time'); Blog.prototype.alertInfo = function() { alert(thia.name + this.url); } }}var blog = new Blog('wuyuchang', 'http://tools.jb51.net'), blog2 = new Blog('wyc', 'http:***.com');
6.寄生构造函数模型
function SpecialArray() { var value=new Array(); value.push.apply(value,arguments); value.toPipedString=function() { return this.join("|"); } return value; } SpecialArray();
7.稳妥构造函数模型
function Process (nameF) { var o = new Object(); var name = nameF;//1 o.sayName = function(){ alert(name);//2 }; return o;}var friend = Process('Nick');friend.sayName(); //"Nick"console.log(friend.name);//undefined//3