关于Js中new操作符的作用详解
程序员文章站
2022-12-01 21:13:51
前言js是当今时代最常用的代码操作语言,其中new操作符尤为常见。对于很多代码小白来说,并不清楚new在js中扮演着怎样的角色,具体是做什么用,干了什么。本文从new操作符的作用着手,简单介绍new操...
前言
js是当今时代最常用的代码操作语言,其中new操作符尤为常见。对于很多代码小白来说,并不清楚new在js中扮演着怎样的角色,具体是做什么用,干了什么。本文从new操作符的作用着手,简单介绍new操作符相关知识。
什么是new?
众所周知,在js中,new的作用是通过构造函数来创建一个实例对象。
像下面这样:(和普通函数不一样,当函数用作构造函数时,首字母一般要大写,以作区分。)
function foo(name) { this.name = name; } console.log("new foo('mm')的类型:",typeof new foo('mm')); // object console.log("foo的类型:",typeof foo); // function
创建了一个空对象
var obj=new object();
在js代码中,new操作符的主要作用是产生对象。通过new创建空对象,为创建对象打基底。
设置原型链
obj.__proto__= func.prototype;
js中在利用new操作符建好基底后,就开始下一步的js代码操作,设置原型链。new通过构造函数创建出的实例可以访问到构造函数原型链中的属性,换言之,通过new操作符,原型链链接了实例和构建函数。
(改变this指向)让func中的this指向obj,并执行func的函数体。
var result =func.call(obj);
一般情况下,在js代码组中,出现this时,构造函数内部是正常工作,但当通过new操作符改变this指向后,所出现的返回值会被正常的返回出去。
判断func的返回值类型:如果是值类型,返回obj。如果是引用类型,就返回这个引用类型的对象。
if (typeof(result) == "object"){ func=result; } else{ func=obj; }
从上述一组new操作符代码中可看出,new还可用来判断func的返回值类型。如果返回值是值类型,则正常返回。如果是引用类型,就返回到引用类型的对象。
以上四点是new操作符在js代码中的主要作用,对于js代码小白希望可以有帮助。
总结
到此这篇关于关于js中new操作符作用的文章就介绍到这了,更多相关js new操作符作用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!