js手写new操作符

简介: 手写new核心代码

每天一道手写题


手写new核心代码

function myNew(fn, ...arg) {
            let obj1 = {}
            if (fn.prototype)
                obj1.__proto__ = fn.prototype
            let res = fn.apply(obj1, arg)
            if (res && (typeof res == 'function' || typeof res == 'object'))
                return res
            return obj1
        }
测试
 function myNew(fn, ...arg) {
            let obj1 = {}
            if (fn.prototype)
                obj1.__proto__ = fn.prototype
            let res = fn.apply(obj1, arg)
            if (res && (typeof res == 'function' || typeof res == 'object'))
                return res
            return obj1
        }
        function a(name, age, height) {
            this.name = name
            this.age = age
            this.height = height
        }
        a.prototype.sayHi = () => {
            console.log('my name is Li Hua');
        }
        let p = myNew(a, 'giegie', 18, 180)
        console.log(p);
        p.sayHi()



相关文章
|
4月前
|
JavaScript 前端开发 算法
JavaScript 中算术操作符:全面解读、实战应用与最佳实践
【4月更文挑战第5天】本文探讨JavaScript中的算术操作符,包括加、减、乘、除、求余、自增、自减及复合赋值等,强调理解与熟练运用它们对提升编程效率和代码准确性的重要性。文中通过示例介绍了各种操作符的用法,同时提醒注意数据类型转换、浮点数精度、除以零错误以及利用短路求值优化逻辑等问题。通过学习,读者能更好地掌握算术操作符在不同场景的应用,提升编程技能。
51 1
|
4月前
|
JavaScript 前端开发 安全
javascript中的可选链操作符
javascript中的可选链操作符
|
4月前
|
JavaScript 前端开发 Java
【面试题】new 一个对象时,js 做了什么?
【面试题】new 一个对象时,js 做了什么?
|
23天前
|
JavaScript
ES6学习(9)js中的new实现
ES6学习(9)js中的new实现
|
1月前
|
JavaScript 前端开发 开发者
深入解析JavaScript中的比较操作符
【8月更文挑战第20天】
18 0
|
4月前
|
JavaScript 前端开发
探索JavaScript中的New操作符:原理与使用
探索JavaScript中的New操作符:原理与使用
|
4月前
egg.js 24.12sequelize模型-where操作符
egg.js 24.12sequelize模型-where操作符
55 1
egg.js 24.12sequelize模型-where操作符
|
4月前
|
JavaScript 前端开发
javascript中new关键字的本质是什么
javascript中new关键字的本质是什么
|
4月前
|
存储 JavaScript 前端开发
JavaScript 自定义对象 及 new()原理与实现 如何完整地手写实现new
JavaScript 自定义对象 及 new()原理与实现 如何完整地手写实现new
160 0
|
4月前
|
JavaScript 前端开发
js中new关键字的作用,new一个对象的过程中发生了什么
js中new关键字的作用,new一个对象的过程中发生了什么