原生js实现继承
- 原型链继承
function Father(){
this.status = true;
}
Father.prototype.getSuper = function(){
return this.status;
};
function Son(){
this.substatus = false;
}
//继承了 SuperType
Son.prototype = new Father();
Son.prototype.getSub = function (){
return this.substatus;
};
var instance = new Son();
alert(instance.getSuper()); //true - 借用构造函数继承
function Father(){
this.colors = [1,2,3];
}
function Son(){
//继承了 Father
Father.call(this);
}
var instance1 = new Son();
instance1.colors.push(4);
alert(instance1.colors); //"1,2,3,4"
var instance2 = new Son();
alert(instance2.colors); //"1,2,3" - 组合继承
function Father(name){
this.name = name;
}
Father.prototype.sayName = function(){
alert(this.name);
};
function Son(name, age){
//继承属性
SuperType.call(this, name);
this.age = age;
} Son.prototype = new Father(); //将子类的原型指向父类
Son.prototype.constructor = Son; //将子类的constructor指向自己
Son.prototype.sayAge = function(){
alert(this.age);
};
var instance = new Son("lh", 19);
instance1.sayName(); //"lh";
instance1.sayAge(); //19 - 原型式继承
function object(o){
function F(){}
F.prototype = o;
return new F();
}
var person = {
name: "lh",
loves: ["a", "b", "c"]
};
var anotherPerson = object(person);
anotherPerson.name = "Greg";
anotherPerson.friends.push("d");
alert(person.loves); //"a,b,c,d"这里的object方法和Object.create()方法类似。
- 寄生式继承
function object(o){
function F(){}
F.prototype = o;
return new F();
}
function createAnother(obj){
var clone = object(obj); //通过调用函数创建一个新对象
clone.say = function(){ //给这个对象添加方法
alert("hi");
};
return clone; //返回这个对象
}
var person = {
name: "lh",
loves: ["a", "b", "c"]
};
var anotherPerson = createAnother(person);
anotherPerson.say(); //"hi" - 寄生组合式继承
function inheritPrototype(son, father){
var prototype = Object.create(father.prototype);
son.prototype = prototype;
prototype.constructor = son;
}
function Father(name){
this.name = name;
}
Father.prototype.sayName = function(){
alert(this.name);
};
function Son(name, age){
Father.call(this, name);
this.age = age;
}
inheritPrototype(Son, Father); - 使用es6实现
class Father{
constructor(x, y) {
this.x = x;
this.y = y;
}
}
class son extends Father{
constructor(x, y, age) {
super(x, y); // 调用父类的constructor(x, y)
this.age= age;
}
toString() {
return this.color + ' ' + super.toString(); // 调用父类的toString()
}
}
子类继承父类中constructor中必须先调用super()方法才能访问this,否则会报错。
原生js实现继承的更多相关文章
- koa 基础(十七)原生 JS 中的类、静态方法、继承
1.app.js /** * 原生 JS 中的类.静态方法.继承 * es5中的类和静态方法 */ function Person(name, age) { // 构造函数里面的方法和属性 this. ...
- 用原生JS读写CSS样式的方法总结
为了日后方便查询,本人翻阅了一些资料总结了以下方法,仅限原生JS,如有不对的地方欢迎指出!只求大家看完觉得有学到点什么就OK了! 一.可以通过DOM节点对象的style对象(即CSSStyleDe ...
- 框架操作DOM和原生js操作DOM比较
问题引出 对于Angular和React操作DOM的速度,和原生js操作DOM的速度进行了一个比较: 一个同学做的demo 代码如下: <!DOCTYPE html> <html n ...
- 原生js dom记忆的内容
1.DOM基础getElementByIdgetElementByTagNamegetElementByName getElementsByClass querySelector querySelec ...
- 原生JS面向对象思想封装轮播图组件
原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...
- 原生js+css实现重力模拟弹跳系统的登录页面
今天小颖把之前保存的js特效视频看了一遍,跟着视频敲了敲嘻嘻,用原生js实现一个炫酷的登录页面.怎么个炫酷法呢,看看下面的图片大家就知道啦. 效果图: 不过在看代码之前呢,大家先和小颖看看css中的o ...
- 原生Js操作DOM
查找DOM .querySelectorAll(),它接受包含一个CSS选择器的字符串参数,返回一个表示文档中匹配选择器的所有元素的NodeList元素. .querySelector(),返回第一个 ...
- 原生JS插件(超详细)
作为一个前端er,如果不会写一个小插件,都不好意思说自己是混前端界的.写还不能依赖jquery之类的工具库,否则装得不够高端.那么,如何才能装起来让自己看起来逼格更高呢?当然是利用js纯原生的写法啦. ...
- 原生js实现vue组件功能
在如今VUE盛行的情况下,我们一直在惊叹于VUE的组件的功能,却不知道,原生js早就已经支持了这个功能. 最近在公开课学到的,js还有很多很多需要探索学习. 下面是一个简单的例子 <!DOCTY ...
随机推荐
- Spring → 04:Bean(1)
一.Bean概念 Spring Bean是被实例的,组装的及被Spring 容器管理的Java对象. Spring 容器会自动完成@bean对象的实例化. 创建应用对象之间的协作关系的行为称为:装配( ...
- Directx11教程(58) 鼠标控制摄像机
原文:Directx11教程(58) 鼠标控制摄像机 本篇教程我们实现鼠标旋转摄像机的操作.主要就是按下鼠标左键的时候,根据鼠标的移动对摄像机进行pitch, raw的组合旋转.具体修改 ...
- python 缺失值处理
- pl/sql基础知识—定义并使用变量
n 介绍 在编写pl/sql程序是,可以定义变量和常量:在pl/sql程序中包括有: ①标量类型(scalar) ②复合类型(composite) ③参照类型(reference) ④lob(lar ...
- Myeclipse运行提示错误: 找不到或无法加载主类 test.test1 终极解决办法
前提是代码没有问题 简单粗暴的解决办法: 重启电脑 解决办法2: 1.在控制台中点开“Problems”,查看里面的错误.如果是多个项目,可以将其他项目暂时关闭. 根据错误进行处理. 2.把项目cle ...
- Extended Traffic
题目链接 题意:有n个路口,m条通路,如果经过一条路则会得到(终点 - 起点)^3的权值,求从1点到其他点的最小权值,如果权值小于3或无法到达输出'?'. 题解:因为权值可能为负,所以用SPFA来解题 ...
- 原生js扫雷代码
思路要点: 1. 随机地雷放到一个二维数组中: 2. 每一个格子要统计周围有几颗雷: 3. 每一个格子是否处于打开状态,用于判断是否赢得游戏: 4. 如果点击到周围没有雷的地方,把周围的打开: 具体的 ...
- EL表达式简单总结
EL表达式 ## EL表达式的取值范围 JSP的四个作用域: pagecontext(生命周期用户离开或者跳转页面,作用域范围这个页面) request(生命周期用户离开页面,作用于这个页面) ses ...
- ADO.NET sqlHelper类(DBHelper类)
1.配置文件 <connectionStrings> <add name="constr" connectionString="Data Source= ...
- 巨蟒python全栈开发-第11阶段 ansible3_4
1.ansible roles 2.nginx+uwsgi扩展 3.celery异步任务 4.celery延时任务 5.周期任务 6.celery与django结合 7.网络基础 8.celery监 ...