Es5中的类和静态方法 继承(原型链继承、对象冒充继承、原型链+对象冒充组合继承)函数
// es5里面的类 //1.最简单的类 // function Person(){ // this.name='张三'; // this.age=20; // } // var p=new Person(); // alert(p.name); //二、构造函数和原型链里面增长方法 // function Person(){ // this.name='张三'; /*属性*/ // this.age=20; // this.run=function(){ // alert(this.name+'在运动'); // } // } // //原型链上面的属性会被多个实例共享 构造函数不会 // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // var p=new Person(); // // alert(p.name); // // p.run(); // p.work(); //3类里面的静态方法 // function Person(){ // this.name='张三'; /*属性*/ // this.age=20; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.getInfo=function(){ // alert('我是静态方法'); // } // //原型链上面的属性会被多个实例共享 构造函数不会 // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // var p=new Person(); // p.work(); // //调用静态方法 // Person.getInfo(); // 四、es5里面的继承 对象冒充实现继承 // function Person(){ // this.name='张三'; /*属性*/ // this.age=20; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // //Web类 继承Person类 原型链+对象冒充的组合继承模式 // function Web(){ // Person.call(this); /*对象冒充实现继承*/ // } // var w=new Web(); // // w.run(); //对象冒充能够继承构造函数里面的属性和方法 // w.work(); //对象冒充能够继承构造函数里面的属性和方法 可是无法继承原型链上面的属性和方法 // 五、es5里面的继承 原型链实现继承 // function Person(){ // this.name='张三'; /*属性*/ // this.age=20; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // //Web类 继承Person类 原型链+对象冒充的组合继承模式 // function Web(){ // } // Web.prototype=new Person(); //原型链实现继承 // var w=new Web(); // //原型链实现继承:能够继承构造函数里面的属性和方法 也能够继承原型链上面的属性和方法 // //w.run(); // w.work(); // 六、 原型链实现继承的 问题? // function Person(name,age){ // this.name=name; /*属性*/ // this.age=age; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // var p=new Person('李四',20); // p.run(); // function Person(name,age){ // this.name=name; /*属性*/ // this.age=age; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // function Web(name,age){ // } // Web.prototype=new Person(); // var w=new Web('赵四',20); //实例化子类的时候无法给父类传参 // w.run(); // // var w1=new Web('王五',22); //7.原型链+对象冒充的组合继承模式 // function Person(name,age){ // this.name=name; /*属性*/ // this.age=age; // this.run=function(){ /*实例方法*/ // alert(this.name+'在运动'); // } // } // Person.prototype.sex="男"; // Person.prototype.work=function(){ // alert(this.name+'在工做'); // } // function Web(name,age){ // Person.call(this,name,age); //对象冒充继承 实例化子类能够给父类传参 // } // Web.prototype=new Person(); // var w=new Web('赵四',20); //实例化子类的时候无法给父类传参 // // w.run(); // w.work(); // // var w1=new Web('王五',22); //八、原型链+对象冒充继承的另外一种方式 function Person(name, age) { this.name = name; /*属性*/ this.age = age; this.run = function () { /*实例方法*/ alert(this.name + '在运动'); } } Person.prototype.sex = "男"; Person.prototype.work = function () { alert(this.name + '在工做'); } function Web(name, age) { Person.call(this, name, age); //对象冒充继承 能够继承构造函数里面的属性和方法、实例化子类能够给父类传参 } Web.prototype = Person.prototype; var w = new Web('赵四', 20); //实例化子类的时候无法给父类传参 w.run(); // w.work(); // var w1=new Web('王五',22);