javascript 对象初探(二)--- 返回对象的函数

了使用new操作符调用构造函数以外,我们也可以抛开new操作符,只用一般函数来创建对象,这样就能执行某些预备工作,并已对象为返回值的函数。、

function her(){
    return {
        name : 'Jon'
    };
}

然后我们调用her()来生成对象:

var a = her();
a.name; // Jon
console.log(a.constructor);
// function Object(){}

 

实际上构造函数也是可以返回对象的,只不过this的值使用上将会有所不同。

function Her(){
   this.name = 'Jon';
   return {
       sex : 'nv'
    }
}
var she = new Her();
she.name;  // undefined;
she.sex; // 'nv'

 

在这里,构造其函数不是返回包含属性name的this对象,而是返回包含属性sex的独立对象。但这也是在返回值是一个对象的前提下,如是一个非对象,照常会返回this.

关于对象是如何在构造函数内部被创建出来的,你可以这样理解:

function Her(){
   // var this = {};
    this.name = 'Jon';
   // return this;
}

 

转载于:https://www.cnblogs.com/beyond-succeed/p/5814518.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值