`
张闯闯1994
  • 浏览: 19677 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
社区版块
存档分类
最新评论

用object( )方法实现非构造函数的继承

阅读更多

    非构造函数继承即不使用构造函数实现继承,让一个对象继承另一个对象:

var parent = { 
      surname : '张'
}
var child = {
       first_name : '小凡'
}

    如上,两个普通的对象,无法使用构造函数方法实现继承,想实现继承,我们可以使用json格式的发明人Douglas  Crockford提出的一个object()函数:

 

 function object(o) {
    function F() {}
    F.prototype = o;
    return new F();
  }

    这个函数其实就做了一件事,就是把子对象(F)的prototype属性指向了父对象(o),使用这个函数:

 

 

var  child= object(parent);
  child.first_name='小凡';
console.log(child.surname);//张

    先用父对象生成子对象,再重新赋予子对象本身的属性,这样就实现了子对象对父对象的继承。

 

 

分享到:
评论

相关推荐

    js定义类 对象 构造函数,类的继承

    通过分析这个文件,我们可以看到实际应用中的类定义和继承实践,包括如何定义类,如何使用构造函数初始化对象,以及如何通过`extends`关键字实现类的继承和覆盖或扩展父类的方法。 总结一下,JavaScript的类、对象...

    Python子类继承父类构造函数详解

    如果子类希望使用父类的构造函数,可以使用`super()`函数来实现: ```python class Son(Father): def __init__(self, name): super(Son, self).__init__(name) # 调用父类的构造函数 print("hi") ``` 这样,在...

    JavaScript 原型继承之构造函数继承

    JavaScript中的构造函数继承是基于原型继承的一种实现方式,它允许一个构造函数(子类)从另一个构造函数(父类)那里继承属性和方法。在JavaScript中,每个对象都有一个[[Prototype]]内部属性,通常通过`__proto__`...

    Javascript 设计模式之构造函数模式.zip

    构造函数模式的核心在于使用函数来创建具有相似属性和方法的对象。在JavaScript中,函数可以作为构造函数来调用,通过`new`关键字创建一个新的实例。这种模式允许我们创建自定义类型的对象,而不仅仅是使用内置类型...

    js 实现类式继承

    在ES6中,`class`关键字提供了一种更简洁、易读的方式来声明构造函数和方法。例如: ```javascript class Animal { constructor(name) { this.name = name; } speak() { console.log(`${this.name} makes a ...

    javascript继承之工具函数二

    2. **构造函数继承**:通过调用父类的构造函数来实现,通常与`call`或`apply`方法结合使用,使得子类实例可以访问父类的属性和方法。但这种方式会为每个子类实例创建不必要的父类属性副本。 3. **组合继承**:结合...

    C#多态性实例,向基类构造函数传递参数.rar

    这个实例"向基类构造函数传递参数"将深入探讨如何在派生类中调用基类的构造函数,并传递参数以实现更灵活的代码设计。以下是对这个主题的详细讲解: 首先,让我们理解什么是多态性。多态性(Polymorphism)是指一个...

    构造函数与析构函数_构造函数ppt_

    在编程领域,特别是面向对象编程(Object-Oriented Programming,OOP)中,构造函数与析构函数是两个至关重要的概念。它们在类的生命周期管理中扮演着核心角色,确保对象的正确初始化和清理。本PPT文件"3.1构造函数...

    学习javascript面向对象 javascript实现继承的方式

    借用构造函数继承又被称为伪造对象继承或经典继承。这种方法在子类型构造函数的内部调用超类型构造函数。通过使用apply()和call()方法,可以在将来新创建的对象上执行构造函数,从而实现继承。 优点: - 可以向超...

    Javascript非构造函数的继承

    这里要注意,这两个对象都是普通对象,不是构造函数,无法使用构造函数方法实现”继承”。 二、object()方法 json格式的发明人Douglas Crockford,提出了一个object()函数,可以做到这一点。 function object(o

    第七课 构造函数-011

    实例化是将抽象的构造函数转化为具体的对象的过程,使得我们可以直接操作和使用对象的属性和方法。 实例化的内部过程包括: - 创建一个新对象。 - 将新对象的上下文(作用域)设置为构造函数,使`this`关键字指向新...

    es5生成class支持构造传参继承函数复用多继承

    我们可以使用`Object.create`方法来创建一个新的对象,这个对象的原型是另一个对象,从而实现继承: ```javascript function Student(name, grade) { Person.call(this, name); this.grade = grade; } Student....

    Javascript面向对象编程(三) 非构造函数的继承

    今天是最后一个部分,介绍不使用构造函数实现”继承”。... 这里要注意,这两个对象都是普通对象,不是构造函数,无法使用构造函数方法实现”继承”。 二、object()方法 json格式的发明人Douglas Crockford,提

    js代码-JS的继承 1、原型继承 2、构造函数的继承 3、组合继承 4、原型式继承 5、寄生式继承 6、寄生式组合继承

    这种方法避免了构造函数继承的问题,但不能向子类传递初始化参数。 5. **寄生式继承**: 在原型式继承的基础上,创建一个辅助函数来复制父对象的属性到新对象,这样可以避免直接操作原型。这解决了原型式继承不能...

    js代码-构造函数继承方式

    在构造函数继承中,我们通常使用`call`或`apply`方法来实现。这两个方法都是Function对象的内置方法,它们允许我们改变`this`的上下文并调用函数。例如: ```javascript function Parent(name) { this.name = name...

    js代码-组合继承(原型链继承+构造函数继承)

    在JavaScript中,组合继承是一种常见的继承模式,它结合了原型链继承和构造函数继承的优点,以实现更灵活的对象创建和复用。这种模式是通过在子类构造函数中调用父类构造函数来继承属性,然后通过原型链来继承方法。...

    java script 继承的实现

    在 JavaScript 中,继承主要通过原型链(prototype chain)、构造函数继承、组合继承、原型式继承、寄生式继承、寄生组合式继承等方法实现。以下是对这些继承方式的详细解释: 1. **原型链继承**:这是 JavaScript ...

Global site tag (gtag.js) - Google Analytics