Javascript + Angular + Prototype清除对象属性

时间:2016-05-17 10:04:16

标签: javascript angularjs

我有点困惑,我希望有一个函数可以清除对象的所有实例都可以使用的对象的所有属性。所以,我添加了一个原型clear()函数。这是以下代码:

(function () {

Supplier.$inject = [];

angular.module('webclient').factory('Supplier', Supplier);

function Supplier() {

    Supplier.prototype = {
        clear: function () {
            for (var key in this) {
                //skip loop if the property is from prototype
                if (this.hasOwnProperty(key))
                    continue;


                console.log("key:" + key);
                this[key] = undefined;
            }
        },
    }

    return Supplier;
};
})();

因此,我希望能够清除当前供应商对象的所有属性。因此,如果供应商对象具有以下属性:

供应商ID:21, 电子邮件:无

我想将属性设置为undefined。我会使用以下类:

var supplier = new Supplier();

supplier.SupplierID = 21; supplier.Email ="无&#34 ;;

要将每个属性设置为undefined,我会

supplier.clear();

有什么想法吗?

由于

3 个答案:

答案 0 :(得分:1)

如果key不在原型中,

hasOwnProperty返回true也应该在构造函数之外设置原型,所以你的代码应如下所示:

function Supplier() { }

Supplier.prototype = {
    clear: function () {
        for (var key in this) {
            if (this.hasOwnProperty(key)) {
                console.log("key:" + key);
                this[key] = undefined;
            }
        }
    },
}

答案 1 :(得分:1)

试试这个:(plnkr

function Supplier() {
    var supplier = function() {};
    supplier.prototype.clear = function() {
      for (var key in this) {
          if (!this.hasOwnProperty(key))
              continue;
          delete this[key];
      }
    };
    return supplier;
}

答案 2 :(得分:0)

不要将属性设置为undefined,只需将delete()设置为:

delete this[key];

并且@jcubic是正确的,如果原型中的键不是,则hasOwnProperty返回true ...