How to remove all getters and setters from an obje

2019-08-01 19:48发布

问题:

I'm using a library called which takes a JS object as an input. Unfortunately, the JSONP api that I am using returns an object containing getters and setters, which this particular library does not know how to handle.

How can I remove all getters and setters from an object while retaining the values of the properties, so I have a Plain Old JavaScript Object?

回答1:

a solution for this special case/environment/setting might look like that ...

var
  obj = JSON.parse(JSON.stringify(model));

console.log("obj before : ", obj);

Object.keys(obj).reduce(function (obj, key) {

  if (obj["_" +  key] === obj[key]) {
    delete obj["_" +  key];
  }
  return obj;

}, obj);

console.log("obj after : ", obj);

see also ... http://jsfiddle.net/w23uLttu/8/



回答2:

After trying all sorts of things such as serializing to JSON and back, I ended up writing a simple shallowClone function to handle this:

const shallowClone = (obj) => {
  return Object.keys(obj).reduce((clone, key) => {
    clone[key] = obj[key];
    return clone;
  }, {});
}


回答3:

Use getOwnPropertyDescriptors to get all the current descriptors, find those with get property, and redefine them. However, you will only be able to do this if the property is configurable.

const descriptors = Object.getOwnPropertyDescriptors(obj);

Object.keys(descriptors)
  .filter(key => descriptors[key].get)
  .forEach(key => Object.defineProperty(obj, key, {value: obj[key]}));

Object.getOwnPropertyDescriptors is an ES7 proposal. Meanwhile, here's an implementation from here:

function getOwnPropertyDescriptors(obj) {
  const result = {};
  for (let key of Reflect.ownKeys(obj)) {
      result[key] = Object.getOwnPropertyDescriptor(obj, key);
  }
  return result;
}