This is the 17th day of my participation in the August Challenge

This series also does not have any tricks, is to complete the usual interview some handwriting functions, test these simple implementation of the advantage is that you can see the basic coding level, and take a short time, a more comprehensive view of your code strength. Generally, there are not many boundary conditions, so that the interview time is not enough, the investigation is not comprehensive.

If you don’t know or are not clear about the API, just ask the interviewer directly, how to use the API under Google anyone can immediately understand the knowledge also can’t see the level. The key is in the implementation process, and your coding status, habits, clarity of thought and so on.

Note that it is a simple implementation, not a complete implementation. It is important to have a clear concept and clear implementation idea. It is suggested to explain the concept clearly first => write use cases => write pseudocode => implement specific functions, and then optimize step by step.

28. Handwriting of various Inheritance methods (II)

What’s the problem

Inheritance is the core concept of OOP (Object-oriented Programming). This paper introduces the simple handwriting of various inheritance in JS.

For prototype related knowledge, please see my core concepts series article to explain the prototype and inheritance in JS (part 1) inheritance related core concepts are being written, please look forward to. This article only provides examples of handwriting styles as supplements to the core concepts. That will be a detailed analysis of the various inheritance methods.

To start with, inheritance is about reuse, say you have the object People and its properties and methods, and you want student and worker to be variations based on people. We want to reuse the content in People, not copy/re-implement its methods, but just build a new object on top of it. So let’s look at some simple implementations of inheritance.

We spent a lot of time last time

  • Prototype chain inheritance
  • Constructor inheritance
  • Combination of inheritance

And then the next canto, if you haven’t read the advice from the last one read it first, it’s a step-by-step process

  • Parasitic inheritance
  • Parasitic combinatorial inheritance

Parasitic inheritance

Parasitic inheritance simply encapsulates the inheritance process in a function.

It creates a function that only encapsulates the inheritance process, enhances the object in some form internally, and returns the enhanced object.

Is in the original way of inheritance, change a way of writing, but there are still defects of prototype chain inheritance or constructor inheritance. The defect depends on the inheritance method you use to encapsulate the function. So this kind of inheritance is an idea or a way of writing.

  • Using the prototype chain inheritance
    • Properties of reference types are shared by all instances
    • When creating an instance of Child, you cannot pass an argument to the Parent
  • Inheritance with constructors
    • Methods are created every time an object is created, resulting in a waste of memory

So here’s the code

Note the object.create () method creates a new Object, using an existing Object to provide the __proto__ of the newly created Object

function createEnhanceObj(obj) {
  // Use obj as the prototype for the new object
  let clone = Object.create(obj);
  // Enhance this object to add methods
  clone.coding = function () {
    console.log('I am coding ! ');
  }
  return clone
}


let parent = { 
  name: 'ParentName'.actions: ['eat'.'reading']}// We augment the Child object with encapsulated inheritance functions
let child = createEnhanceObj(parent)

console.log(child.name) // ParentName
console.log(child.actions) // [ 'eat', 'reading' ]
child.coding() //I am coding !

// Attributes of the reference type are shared by all instances
parent.actions.push('sleep')
console.log(child.actions) // [ 'eat', 'reading', 'sleep' ]

// Methods are created every time an object is created, resulting in a waste of memory
let child2 = createEnhanceObj(parent)
console.log(child.coding === child2.coding) // false
Copy the code

As can be seen from the following two cases, there are still some problems before

So let’s combine the combinatorial and the parasitic to create a better parasitic combinatorial inheritance

Parasitic combinatorial inheritance

Before looking at this approach, I recommend reviewing combinatorial inheritance, since you need to understand the characteristics of both

function Parent (name, actions) {
    this.name = name;
    this.actions = actions;
}

Parent.prototype.play = function () {
  console.log(`The ${this.name} is playing`)}function Child () {
  Parent.apply(this.arguments);
}

// This is the same as combinatorial inheritance
// The constructor is called once like this:
// Child.prototype = new Parent();
/ / = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
// Now it is written in a parasitic way to keep the prototype chain context

// This is the Object. Create core implementation code
function myCreateObj(obj) {
  // create a new constructor inside F
  function F() {}
  // Point the constructor's prototype property to the object passed in
  F.prototype = obj;
  // Create an instance of the constructor and return it
  return new F();
}

function createEnhanceObj(child, parent) {
    let prototype = myCreateObj(parent.prototype);
    prototype.constructor = child;
    child.prototype = prototype;
}

createEnhanceObj(Child, Parent);

let child1 = new Child('k'['eat'.'sleep'.'coding']);

console.log(child1.name); // k
console.log(child1.actions); // ['eat', 'sleep', 'coding']

let child2 = new Child('cd'['eat'.'sleep']);

console.log(child2.name); // cd
console.log(child2.actions); // ['eat', 'sleep']
child2.play(); // cd is playing

console.log(child1.play === child2.play) // true

console.log(child1 instanceof Parent) // true
Copy the code

One of the core implementations of Object.Create is key, so we can simplify

function Parent (name, actions) {
    this.name = name;
    this.actions = actions;
}

Parent.prototype.play = function () {
  console.log(`The ${this.name} is playing`)}function Child () {
  Parent.apply(this.arguments);
}

function createEnhanceObj(Parent, Child){
    // Set the prototype of child. prototype to parent. prototype
    Child.prototype = Object.create(Parent.prototype);
    // Keep the constructor point consistent
    Child.prototype.constructor = Child;
}

// Alternatively, assign the superclass prototype to the subclass and set the constructor to the subclass
// function createEnhanceObj(Parent, Child){
// Child.prototype = Object.create(Parent.prototype, {
// constructor: {
// value: Child,
// enumerable: false,
// writable: true,
// configurable: true
/ /}
/ /})
// }

createEnhanceObj(Parent, Child)



let child1 = new Child('k'['eat'.'sleep'.'coding']);

console.log(child1.name); // k
console.log(child1.actions); // ['eat', 'sleep', 'coding']

let child2 = new Child('cd'['eat'.'sleep']);

console.log(child2.name); // cd
console.log(child2.actions); // ['eat', 'sleep']
child2.play(); // cd is playing

console.log(child1.play === child2.play) // true

console.log(child1 instanceof Parent) // true
Copy the code

We can see the advantages of parasitic combinatorial inheritance

  1. The Parent constructor is called only once and thus avoids creating unnecessary, redundant properties on Parent. Prototype

  2. The prototype chain context is guaranteed to remain unchanged. Therefore, instanceof and isPrototypeOf can also be used normally.

Parasitic combinatorial inheritance is generally considered by developers to be the ideal inheritance paradigm for reference types. Most Js frameworks use this as an inheritance scheme.

That’s all for today and tomorrow we’ll focus on some uses of syntactic sugar ES6 class/extends.

In addition, we recommend another series of articles, very simple, on the front of the advanced students are very effective, wall crack recommended!! Core concepts and algorithms disassembly series remember to like ha

If you want to brush the questions with me, you can add me on wechat. Click here to make a friend Or search my wechat account, infinity_9368. You can chat with me and add my secret code “Tianwang Gaidihu”. Verify the message please send me Presious tower shock the rever Monster, I see it through, after adding I will do my best to help you, but pay attention to the way of asking questions, it is suggested to read this article: the wisdom of asking questions

reference

  • Juejin. Cn/post / 684490…
  • MDN
  • elevation