JavaScript中判断函数是new还是调用的区别说明
3个回答
2016-07-19 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
关注
展开全部
如果是最典型的构造函数模式,必须加上new:
function Man(age){
this.sex="male";
this.age=age;
}
m1=Man(20);
m2=new Man(21);
m1就是函数Man()执行的返回值,也就是undefined. 在函数执行过程中,属性被加到全局作用域或者Man方法所属的对象上了。执行之后window.sex=="male"
而m2是Man的实例,Man {sex:"male",age:21}
function Man(age) {
var obj = new Object();
obj.sex = "mail";
obj.age = age;
return obj;
}
m3=Man(22);
这个就不需要加new,m3是一个Object,不是Man的实例。
native code中,加new就是返回这个构造函数的实例;不加作为函数就返回一个基本数据类型,或者会报错 “ DOM object constructor cannot be called as a function ”。
Date(),不加new返回当前时间,是一个字符串。加new的话,返回当前时间或者把参数格式化得到的时间,是一个Date对象。
String(),不加new将参数格式化为字符串,加new则返回的是String对象。它们的区别如下:
var s1=new String(2);
//如果把s1 log到控制台中,输出 String{0:"2"}
var s2=String(2);
//如果把s2 log到控制台中,输出 '2'
console.log(typeof s1);
//"object"
console.log(typeof s2);
//"string"
s1.pro = 1;
console.log(s1.pro);
//1
s2.pro = 1;
console.log(s2.pro);
//undefined
Number和String类似。
Array,Object加不加new貌似是一样的?
Image,XMLHttprequest等不能作为函数使用。
function Man(age){
this.sex="male";
this.age=age;
}
m1=Man(20);
m2=new Man(21);
m1就是函数Man()执行的返回值,也就是undefined. 在函数执行过程中,属性被加到全局作用域或者Man方法所属的对象上了。执行之后window.sex=="male"
而m2是Man的实例,Man {sex:"male",age:21}
function Man(age) {
var obj = new Object();
obj.sex = "mail";
obj.age = age;
return obj;
}
m3=Man(22);
这个就不需要加new,m3是一个Object,不是Man的实例。
native code中,加new就是返回这个构造函数的实例;不加作为函数就返回一个基本数据类型,或者会报错 “ DOM object constructor cannot be called as a function ”。
Date(),不加new返回当前时间,是一个字符串。加new的话,返回当前时间或者把参数格式化得到的时间,是一个Date对象。
String(),不加new将参数格式化为字符串,加new则返回的是String对象。它们的区别如下:
var s1=new String(2);
//如果把s1 log到控制台中,输出 String{0:"2"}
var s2=String(2);
//如果把s2 log到控制台中,输出 '2'
console.log(typeof s1);
//"object"
console.log(typeof s2);
//"string"
s1.pro = 1;
console.log(s1.pro);
//1
s2.pro = 1;
console.log(s2.pro);
//undefined
Number和String类似。
Array,Object加不加new貌似是一样的?
Image,XMLHttprequest等不能作为函数使用。
展开全部
function Person(n,a){
this.name = n;
this.age = a;
if(this instanceof Person){
alert('new调用');
}else{
alert('函数调用');
}
}
var p = new Person('jack',30); // --> new调用
Person(); // --> 函数调用
this.name = n;
this.age = a;
if(this instanceof Person){
alert('new调用');
}else{
alert('函数调用');
}
}
var p = new Person('jack',30); // --> new调用
Person(); // --> 函数调用
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
。。。什么意思,不太理解呢
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询