javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > js普通函数和构造函数

JS 底层探究之普通函数和构造函数详解

作者:半个烧饼不加肉

这段文章详细解析了JavaScript中的构造函数与普通函数的区别,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

一、核心理论

1. 普通函数 vs 构造函数

例如:

function getUser (name) {
  retrun {name};
}

例如:

// 构造函数(大驼峰命名)
function Person(name, age) {
  // 自身属性
  this.name = name;
  this.age = age;
}

2. new 关键字四大步骤

  1. 创建一个空对象 {}
  2. 这个空对象的 __proto__ 指向构造函数的 prototype
  3. 构造函数内部的 this 指向这个空对象
  4. 如果构造函数没有返回对象,则默认返回这个新对象
// 1. 先定义一个构造函数
function Person(name, age) {
  // 步骤3执行时,this 会变成我们创建的空对象
  this.name = name;
  this.age = age;
}
// ------------------------------
// 核心:手写模拟 new 的4大步骤
// ------------------------------
function myNew(constructor, ...args) {
  // 步骤1:创建一个空对象 {}
  const obj = {};
  // 步骤2:空对象的 __proto__ 指向构造函数的 prototype
  obj.__proto__ = constructor.prototype;
  // 步骤3:执行构造函数,让 this 指向这个空对象
  // call 的作用:把构造函数里的 this 改成 obj
  const result = constructor.call(obj, ...args);
  // 步骤4:如果构造函数没有返回对象,就返回我们创建的 obj
  if (result && typeof result === "object") {
    return result;
  } else {
    return obj;
  }
}
// ------------------------------
// 测试使用
// ------------------------------
const p1 = myNew(Person, "小明", 18);
console.log(p1);       // Person { name: '小明', age: 18 }
console.log(p1.name);  // 小明

3. 实例与构造函数关系

const a = new Person("XIAO MIN", 20);
const b = new Person("XIAO HUA", 29)
console.log(a); // Person { name: 'XIAO MIN', age: 20 }
console.log(b); // Person { name: 'XIAO HUA', age: 29 }

4. 自身属性 vs 原型属性

console.log(a.name); // XIAO MIN
Person.prototype.pName = "Person"
console.log(a.pName); // Person
console.log(b.name) // XIAO HUA
console.log(b.pName) // Person

到此这篇关于JS 底层探究之普通函数和构造函数详解的文章就介绍到这了,更多相关js普通函数和构造函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文