【new操作符做了什么 —— js】

简介: 【new操作符做了什么 —— js】

new操作符具体做了什么?

🎈创建了一个空的对象

function Foo(){
        }
 console.log(new Foo());

从上图中返回了一个对象,可以看出 Foo()为一个对象

✨将空对象的原型,指向于构造函数的原型

function Foo(){
        }
console.log(Foo.prototype == new Foo().__proto__);

显示结果 为true

🍧将空对象作为构造函数的上下文(改变this指向)

🍄未使用new操作符时的this

 function Foo(){
            console.log(this);
            this.name = '张三'
        }
 console.log(Foo());

从上述中我们可以发现 此时构造函数的this为整个window,而window对象下并没有name,所以报出undefined(函数Foo()并没有执行return)

🍄使用new操作符时的this

 function Foo(){
            console.log(this);
            this.name = '张三'
        }
 console.log(new Foo());

此时,this即指向了 new Foo()这个对象

🌋对构造函数有返回值的处理判断

🍬返回基本类型

Number类型、String类型、Boolean类型、Null类型、Undefined类型、Biglnt类型;字符串类型、符号类型。

 function Foo(){
            this.name = '张三'
            return true;
        }
  console.log(new Foo());
································
  function Test(){
            this.name = '张三'
            return 111;
  }
  console.log(new Test());

可以看出:如果构造函数返回基本类型,则忽略返回值

🍬返回引用类型

Object、Array、Function

  function Foo(){
            this.name = '张三'
            return {};
        }
  console.log(new Foo());

可以看出:如果构造函数返回引用类型,则new操作符 无效

🎉🎉🎉如有错误,请评论指出,thankyou~🎀🎀🎀

✨✨✨创作不易,如对您有帮助,欢迎给博主点赞收藏,给予鼓励哟💛

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