Simonzhangs' blog Simonzhangs' blog
首页
  • 前端文章

    • HTML
    • CSS
    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • JS设计模式总结
  • 《Vue》
  • 《React》
  • 《TypeScript 从零实现 axios》
  • TypeScript
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • apple music
  • extension
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Simonzhangs

前端学习探索者
首页
  • 前端文章

    • HTML
    • CSS
    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • JS设计模式总结
  • 《Vue》
  • 《React》
  • 《TypeScript 从零实现 axios》
  • TypeScript
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • apple music
  • extension
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • HTML

  • CSS

  • JavaScript文章

    • 33个非常实用的JavaScript一行代码
    • new命令原理
    • ES5面向对象
    • ES6面向对象
    • 多种数组去重性能对比
    • JS随机打乱数组
    • 判断是否为移动端浏览器
    • 将一维数组按指定长度转为二维数组
    • 防抖与节流函数
    • JS获取和修改url参数
    • 比typeof运算符更准确的类型判断
    • 常见面试题

      • 四级文件(测试)
      • 原型与原型链
      • JS数据类型
      • call、apply、bind
      • JavaScript运行机制
      • promise
      • JS中在new的时候发生了什么
  • 学习笔记

  • 前端
  • JavaScript文章
  • 常见面试题
simonzhangs
2022-03-29

JS中在new的时候发生了什么

  1. 创建了一个新的对象;
  2. 链接到构造函数的原型上;
  3. 绑定this指向;
  4. 返回这个对象。
function _new() {
  let obj = {};
  let Con = [].shift.call(arguments);
  obj.__proto__ = Con.prototype;
  let result = Con.apply(obj, arguments);
  return typeof obj === "object" ? obj : {};
}
1
2
3
4
5
6
7
function Person(name,age) {
  this.name = name;
  this.age = age;
}

function _new() {
  var args = [].slice.call(arguments);
  var constructor = args.shift();
  var context = Object.create(constructor.prototype);
  var result = constructor.apply(context, args);
  return (typeof result === 'object' && result != null) ? result : context;
}

var actor = _new(Person,'张三',28);
1
2
3
4
5
6
7
8
9
10
11
12
13
14

提示

arguments是类数组对象,它是用来存储实参的,而且有存储顺序,也具备和数组相同的访问性质和方式,拥有数组的长度属性length。用来存储实际传递给函数的参数。

具有callee属性,返回正被执行的Function对象;

可以通过slice来讲arguments转换为真实的数组:

  1. Array.prototype.slice.call(arguments);
  2. [].slice.call(arguments)
  3. Array.from(arguments)
  4. [...arguments]

arguments和函数相关联,其只有在函数执行时可用,不能显示创建。

Object.create()方法创建一个新对象,使用现有的对象来提供新创建的对象的__proto__。


参考链接:

  1. JS的arguments (opens new window)
  2. Object.create() (opens new window)
编辑 (opens new window)
上次更新: 2022/05/17, 21:50:47
promise
《JavaScript教程》笔记

← promise 《JavaScript教程》笔记→

最近更新
01
一些有意思的类比
06-16
02
the-super-tiny-compiler解析
06-06
03
计算机编译原理总概
06-06
更多文章>
Theme by Vdoing | Copyright © 2021-2022
蜀ICP备2021023197号-2
Simonzhans | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
  • 飙升榜
  • 新歌榜
  • 云音乐民谣榜
  • 美国Billboard榜
  • UK排行榜周榜