zoukankan      html  css  js  c++  java
  • 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操作符具体干了什么呢?

         [JS] new操作符

         JS 中 new 操作符

  • 相关阅读:
    从开发者角色到产品角色转换
    前端开发做什么?
    最近的前端开发认知总结
    最近的Vue知识总结
    计算机网络
    javascript 字符串加密的几种方法
    JSON数据解析
    JAVA 自定义状态码
    JAVA jdbc获取数据库连接
    JAVA通过md5方法进行加密
  • 原文地址:https://www.cnblogs.com/guorange/p/7146581.html
Copyright © 2011-2022 走看看