手写js的new函数

手写js的new函数

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <!-- 
        总结出new关键字在实例化对象时内部都干了什么。

        其实,new关键字内部干了如下三件事(已知构造函数为constructor):.
        1.创建一个空对象,并使该空对象的 __proto__==constructor.prototype;
        2.执行构造函数,并将this指向刚刚创建的新对象;
        3.返回新对象;

     -->
    <script>
        function myNew() {
            const obj = new Object();
            Constructor = Array.prototype.shift.call(arguments);
            obj.__proto__ = Constructor.prototype;
            let res = Constructor.apply(obj, arguments);
            return res instanceof Object == true ? res : obj
        }

        /**
         *  new产生一个新对象;
            拿到传入的参数中的第一个参数,即构造函数Constructor;
            执行构造函数,并将this指向创建的空对象obj;
            将传入构造函数的参数,在obj上下文中执行一遍;
            如果构造函数返回一个对象,则直接返回这个对象,若构造函数没有返回这个对象,那么就返回obj


            创建一个新的对象,并返回。符合new函数的功能。
            截取传入myNew函数的第一个参数。
            将第一个参数的prototype与要返回的对象建立关联。
            使用apply,改变构造函数的this指向,使其指向新对象,这样,obj就可以访问到构造函数中的属性了。
            返回obj。

        */


        // 检验,这是没有返回值的检验
        // function Person(name, age) {
        //     this.name = name;
        //     this.age = age;
        //     console.log('执行')
        //     return '12'
        // }

        // let zhangsan = myNew(Person, '张三', 12)
        // console.log(zhangsan)


        //  这是构造函数有返回值的检验
        function Person(name, age) {
            this.name = name;
            return{
                age:age
            }
        }

        let zhangsan = myNew(Person, '张三', 12)

        console.log(zhangsan)


    </script>
</body>

</html>

欢迎指正交流

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值