javascript创建对象的相关问题

javascript创建对象的方法有很多种,一般来说,推荐使用对象字面量来创建对象。

对象构造函数捕捉

使用new Object来创建对象,可能会带来一些问题:

var o = new Object();
console.log(o.constructor === Object);//true

var o = new Object(1);
console.log(o.constructor === Object);//false
console.log(o.constructor === Number);//true

var o = new Object("hi");
console.log(o.constructor === String);//true
console.log(typeof o.substring);//'function'

 

自定义构造函数
使用new创建对象时,首先创建一个空对象,然后将其[[prototype]]指向构造函数的原型对象,然后执行构造函数,将this的属性和方法添加到创建的空对象里面,最后隐形返回这个对象:

var Person = function(){
    //var this={};
    this.name = "Rose";
    this.sayName = function(){
        console.log("I am"+this.Name);
    };
    //return this;
};


 

构造函数的返回值:

var Person = function(){
    this.name = "Rose";
    var that = {};
    that.name = "Mary";
    return that;
};

var person = new Person();
console.log(person.name);//"Mary"

就是说,如果返回的是一个对象,将覆盖默认的对象,但是如果返回的不是对象,而是值,虽然不会造成错误,但是函数会忽略该值。

 

强制使用new的模式:

有时候,如果忘记使用new,将造成一些错误,为了避免这类错误,可以使用的写法:

var Person = function(nameStr){
    var that = {};
    that.name = nameStr;
    return that;
};

var girl = new Person("Mary");
console.log(girl.name);//"Mary"

var boy = Person("Mike");
console.log(boy.name);//"Mike"

 

转载于:https://www.cnblogs.com/linda586586/p/4234639.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值