标签:console name 特征 money age Son 面向对象 继承 三大
面向对象三大特征
1、封装
把属性和方法封装成一个对像
2、继承 inherit
ES5继承写法
可以更改指向来继承其他对象的属性和方法
// 【ES5继承】
//爷
function Ye(money) {
this.money = money;
};
let Y1 = new Ye(1200);
Fu.prototype = Y1;//父辈继承爷爷辈
// Object.assign(Fu.prototype,Y1);//父辈继承爷爷辈
//父
function Fu(kg) {
this.kg = kg;
};
let F1 = new Fu(60);
Son.prototype = F1;//孙子辈继承父辈
// Object.assign(Son.prototype,F1);//孙子辈继承父辈
//孙
function Son(age) {
// Fu.call(this,kg);
this.age = age;
};
let S1 = new Son(80);
console.log(F1.money);//1200
console.log(S1.age);//80
console.log(S1.kg);//60
console.log(S1.money);//1200
ES6继承写法:
extends和super配套使用
使用extends继承,类声明的时候添加extends,在extends后面跟继承的类
super必须写在this前面,即写在constructor里的第一行
例: Son继承Father
// 【ES6继承】
class Father {
constructor(name,age,money) {
this.name = name;
this.age = age;
this.money = money;
}
say() {
console.log(this.name, this.sge);
}
};
class Son extends Father {//继承Father
constructor(name, age, money) {
super(name,age,money);
this.name = name;
this.age = age;
}
say() {
console.log(this.name, this.sge);
}
};
let S1 = new Son("z3",12,100);
console.log(S1);
Son原型proto本身指向Object的原型,继承以后Son原型proto指向继承类(即Father)的原型
3、多态polymoiphism
同一个模具,生产出不同的产品
同一个构造函数或类,实例化出不同的对象(根据参数不同)
不同的实例对象,调用同一个方法,得到不同的结果
例:
class Students{
constructor(name,age,gender){
this.name = name;
this.age = age;
this.gender = gender;
}
};
let stu1 = new Students("z3",18,"男");
let stu2 = new Students("l4",20,"女");
let stu3 = new Students("w5",22,"男");
标签:console,name,特征,money,age,Son,面向对象,继承,三大 来源: https://blog.csdn.net/jianbangwie520/article/details/120977252
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。