4

私がこれを行うことができれば、非常に便利です:

var MyObject = function(param1, param2, ... paramN)
{
    this.var1 = stuff;
    this.var2 = moreStuff;
    .
    .
    .
    this.varN = nStuff;

    this.validate = function()
    {
        for(var current in this)
        {
            alert(current);
            //validate all member variables (even this function I suppose)
        }
    };
};

しかし、これは私が望むことをしていないようです。ループは最終的にその親関数をループする必要があることに気付きました (これも驚くことではありませんが、起こりません)。

2 番目の関数の「this」が最初の関数ではなく 2 番目の関数を参照しているため、これは不可能ですか? それとも、キーワード 'this' は public メンバーの宣言演算子であり、外部オブジェクトへの参照ではありませんか?

この方法で欲しいものを手に入れることは不可能だと思いますが、この動作を達成するためにできる別の方法はありますか?

4

2 に答える 2

5

メンバーの値を取得しようとしていると思いますが、間違った方法で行っているので、これを試してください:

      var MyObject = function() {
        this.var1 = 'var 1 value';
        this.var2 = 'var 2 value';
        this.varN = 'var n value';
        var self = this;

        this.validate = function() {
          for (var member in self) {
            if (!self.hasOwnProperty(member) || typeof(self[member]) === "function") continue;
            alert(self[member]);
          }
        };
      };

      var m = new MyObject();
      m.validate();

説明: ループは、プロパティが Object オブジェクトから継承されているのではなく、ユーザー定義のプロパティであるかどうかを最初に確認します。また、メンバーが関数 (validate() など) ではないことも確認し、メンバーの値を警告します。

ダグラス・クロックフォード (JS の父) は、メンバを反復処理する際のベスト プラクティスとして hasownproperty チェックを推奨しています。

お役に立てれば、

ダルコ

編集:言及するのを忘れましたself-これが実際にあなたが望むものであることを確認する標準的な方法であるため、これを含めました。

于 2009-07-12T05:21:57.913 に答える
1

どのように電話していvalidateますか?

次のコードは私にとってはうまくいきます:

var MyObject = function(){
    this.var1 = 'stuff';
    this.var2 = 'moreStuff';
    this.varN = 'Stuff';

    this.validate = function()
    {
        for(var current in this)
        {
            alert(current);
        }
    };
};

var m = new MyObject();
m.validate();
于 2009-07-12T04:16:11.413 に答える