new操作符实现过程
var obj = new Object(); //创建新对象
一. new是干嘛的?
new操作符用来生成一个新的对象, 它后面必须跟上一个函数(否则, 会抛出TypeError异常), 这个函数就是我们常说的构造函数.
二. new操作构造函数生成实例的过程
(1) 首先, 当我们使用new操作符时, js会先创建一个空的对象;
(2) 然后, 构造函数中的this指向该空对象;
(3) 其次, 在构造函数中通过操作this, 来给这个空对象赋予相应的属性;
(4) 最后, 返回这个经过处理的"空对象"(此时, 对象已经不是空的了).
三. new操作构造函数的注意事项
(1) 如果构造函数的返回值是一个原始类型(非引用对象, 如字符串), 那么返回值为new创建的"空对象", 如:
var obj = new function() { return "code";}; alert(obj); // [object object]
console.log(obj); //{}
(2) 如果构造函数的返回值是一个引用对象(数组, 对象, 函数等), 那么返回值会覆盖new创建的"空对象", 如:
var obj = new function() { return new String("code"); }; alert(obj); // "code"
console.log(obj); //[String: 'code']
写成代码就是如下:
function NewFunc(func){ var ret = {}; if (func.prototype !== null) { ret.__proto__ = func.prototype; } var ret1 = func.apply(ret, Array.prototype.slice.call(arguments, 1)); if ((typeof ret1 === "object" || typeof ret1 === "function") && ret1 !== null) { return ret1; } return ret; }
参考链接:new操作符具体干了什么呢?