1

我用谷歌搜索了一下,似乎我要么不知道我在问什么,要么这是不可能的。我想应该是前者吧。

如果我有一个对象

obj = {
  func : function(){
    return 'hello';
  }
}

我通常会做alert(obj.func())我当然得到"hello"

但是,如果我只想obj.func成为一个变量,那有可能吗?我永远不会将参数传递给函数,我只想将其返回值作为普通变量引用alert(obj.func),而不是函数调用。

谢谢。

4

4 回答 4

6

试试这个 :

obj = {
  func : (function(){
    return 'hello';
  })()
}
于 2013-02-14T22:24:09.923 回答
2

是的,这很容易!

var obj = {
  func :  'hello'
};

alert(obj.func);

看到这个工作小提琴

如果您希望它是计算值或某事。你仍然可以让它成为一个函数,但可以像一个简单的属性一样调用:

var obj = {
  func :  (function(){return 'hello';})()
};
于 2013-02-14T22:24:46.517 回答
2

你在说的是一个 getter :它是一个作为属性工作的函数。它是自 javascript 1.8.5 以来的标准,这意味着旧浏览器将无法处理它。
语法如下,使用您的示例:

obj = {
   get func() {  return "hello" ; }
};
// use like this :
console.log(obj.func);

您很可能还想定义一个 setter:这也是一个行为类似于属性的函数。语法将是:

obj = {
    get func()    { return this._innerText ; },
    set func(txt) { this._innerText = txt  ; },
    _innerText  : "hello" 
};

console.log(obj.func) ;   // output is hello
obj.func = "godd bye" ;
console.log(obj.func) ;   // output is good bye

显然,就像通常的简单示例一样,这个没有太大用处:

让我们看看使用 getter / setter 的角度到弧度的转换器:

 var Angle = {
        get degree ()        { return this._degree ; },
        set degree (dg)      { this._degree = dg   ; },
        get radian ()        { return 2*Math.PI*this.degree/360 ; },
        set radian (rd)      { this._degree = rd * 360 / (2*Math.PI) ; },
        _degree  : 0
} ;
// you can use :
Angle.radian = Math.PI / 2;
console.log ( Angle.degree );    // -->> output is 90
Angle.degree=45 ;
console.log(Angle.radian) ;      // --> output is 0.7853... which is PI/4

您还可以查看 Object.defineProperty,它允许定义标准属性和 getter/setter,但有更多选项,尤其是“隐藏”属性的选项,它允许不枚举它。

更多信息:
https ://developer.mozilla.org/en-US/docs/JavaScript/Reference/Operators/get https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Operators/set https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Object/defineProperty

于 2013-02-14T23:00:47.910 回答
-1
    var varFunc = function() { alert("hello"); }
    varFunc();
于 2013-02-14T22:24:48.460 回答