Search code examples
javascriptjsonserialization

JavaScript Serialization and Methods


I am new to "object-oriented" JavaScript. Currently, I have an object that I need to pass across pages. My object is defined as follows:

function MyObject() { this.init(); }
MyObject.prototype = {
    property1: "",
    property2: "",

    init: function () {
        this.property1 = "First";
        this.property2 = "Second";
    },

    test: function() {
      alert("Executing test!");
    }
}

On Page 1 of my application, I am creating an instance of MyObject. I am then serializing the object and storing it in local storage. I am doing this as shown here:

var mo = new MyObject();
mo.test();                                    // This works
window.localStorage.setItem("myObject", JSON.stringify(mo));

Now, on Page 2, I need get that object and work with it. To retrieve it, I am using the following:

var mo = window.localStorage.getItem("myObject");
mo = JSON.parse(mo);
alert(mo.property1);    // This shows "First" as expected.
mo.test();              // This does not work. In fact, I get a "TypeError"  that says "undefined method" in the consol window.

Based on the outputs, it looks like when I serialized the object, somehow the functions get dropped. I can still see the properties. But I can't interact with any of my functions. What am I doing wrong?


Solution

  • Functions can not be serialized into a JSON object.

    So I suggest you create a separate object (or property within the object) for the actual properties and just serialize this part. Afterwards you can instantiate your object with all its functions and reapply all properties to regain access to your working object.

    Following your example, this may look like this:

    function MyObject() { this.init(); }
    MyObject.prototype = {
        data: {
          property1: "",
          property2: ""
        },
    
        init: function () {
            this.property1 = "First";
            this.property2 = "Second";
        },
    
        test: function() {
          alert("Executing test!");
        },
    
    
       save: function( id ) {
         window.localStorage.setItem( id, JSON.stringify(this.data));
       },
       load: function( id ) {
         this.data = JSON.parse( window.getItem( id ) );
       }
    
    }