像PHP一样使用json数组“水合”Javascript对象实例


"Hydrate" a Javascript Object Instance with json array just like PHP does

这是"问题",我用这样的数据填充PHP对象:

public function hydrate(array $data){
    foreach($data as $key=>$value){
        $method = 'set'.ucfirst($key);
        if(METHOD_EXISTS($this,$method)){
            $this->$method($value);
        }
    }
}

现在,我想将其转换为javascript对象而不是PHP,因此,我通过.ajax调用从数据库中获取"数据数组",并得到一个"看起来像"这样的JSON对象:

{"id":"44","name":"test","testKey":"qklfjmdjfq88"}

我的Javascript"对象"看起来像这样:

function myObject(){
    var element,id,name,testKey;
    this.hydrate = function(ajaxData){
        //THIS CODE DOES NOT WORK
        //THAT IS THE PROBLEM
        Object.keys(ajaxData).forEach(function(key){
            console.log("function loop key : "+key);//OK
            console.log("function loop value : "+ajaxData[key]);//OK
            this.key = Element[key];
        });
    };
}

所以,一旦我在 js 脚本中收到我的 JSON"数组",我想把它变成一个 js 对象实例,所以我正在这样做:

var myCurrentObject = new myObject();
myCurrentObject.hydrate(/*WHAT MY AJAX CALL RETURN*/);
console.log(myCurrentObject.name);
//console shows undefined...

所以问题似乎出在 .hydrate 函数中......这.key与 myObject 实例变量不对应...(名称/ID/测试密钥)如何使用看起来像我在使用 php 时使用的函数填充 js 对象实例?

感谢您的帮助/阅读

在此函数中

this.hydrate = function(ajaxData){
    Object.keys(ajaxData).forEach(function(key){
        console.log("function loop key : "+key);
        console.log("function loop value : "+ajaxData[key]);
        this.key = Element[key];
    });
};

this.key不是指myObject,您应该尝试:

this.hydrate = function(ajaxData){
    Object.keys(ajaxData).forEach(
      // Execute a function passing param this as obj that return a function 
      // (closure)
      (function(obj){
        return function(key){
            obj[key] = ajaxData[key];
        };
      })(this)
    );
};

或将其保存在变量中

this.hydrate = function(ajaxData){
    var that = this;
    Object.keys(ajaxData).forEach(function(key){
        that[key] = ajaxData[key];
    });
};

或更简单地使用 for 循环

this.hydrate = function(ajaxData){
    var k =  Object.keys(ajaxData);
    for(var i=0, len = k.length; i<len; i++){
        this[k[i]] = ajaxData[k[i]];
    }
};