19

如何从以下映射中删除所有键/值对,其中键以 X 开头

var map = new Object(); 
map[XKey1] = "Value1";
map[XKey2] = "Value2";
map[YKey3] = "Value3";
map[YKey4] = "Value4";

编辑

有没有办法通过正则表达式,可能使用 ^ 。类似于 map[^XKe],其中键以“Xke”而不是“X”开头

4

4 回答 4

16

您可以使用Object.key.

最简单的解决方案是这样的:

在这里演示

Object.keys(map).forEach(function (key) {
 if(key.match('^'+letter)) delete obj[key];
});

removeKeyStartsWith因此,正如您所说,这是带有正则表达式的另一个版本:

function removeKeyStartsWith(obj, letter) {
  Object.keys(obj).forEach(function (key) {
     //if(key[0]==letter) delete obj[key];////without regex
           if(key.match('^'+letter)) delete obj[key];//with regex

  });
}

var map = new Object(); 
map['XKey1'] = "Value1";
map['XKey2'] = "Value2";
map['YKey3'] = "Value3";
map['YKey4'] = "Value4";

console.log(map);
removeKeyStartsWith(map, 'X');
console.log(map);

即使您按照您所说的那样使用 letter=Xke 的解决Regex方案也可以满足您的需求,但是对于没有 Regex 的其他解决方案,您将需要替换:

Key[0]==letterkey.substr(0,3)==letter

于 2013-09-03T18:52:26.977 回答
15

我建议:

function removeKeyStartsWith(obj, letter) {
    for (var prop in obj) {
        if (obj.hasOwnProperty(prop) && prop[0] == letter){
            delete obj[prop];
        }
    }
}

JS 小提琴演示

顺便说一句,使用 Object-literal 而不是构造函数通常更容易(并且似乎被认为是“更好的做法”),因此以下内容值得展示(即使出于某种原因,您更喜欢new Object()语法:

var map = {
    'XKey1' : "Value1",
    'XKey2' : "Value2",
    'YKey3' : "Value3",
    'YKey4' : "Value4",
};

JS 小提琴演示

如果您真的想使用正则表达式(但为什么?),那么以下工作:

function removeKeyStartsWith(obj, letter, caseSensitive) {
    // case-sensitive matching: 'X' will not be equivalent to 'x',
    // case-insensitive matching: 'X' will be considered equivalent to 'x'
    var sensitive = caseSensitive === false ? 'i' : '',
        // creating a new Regular Expression object,
        // ^ indicates that the string must *start with* the following character:
        reg = new RegExp('^' + letter, sensitive);
    for (var prop in obj) {
        if (obj.hasOwnProperty(prop) && reg.test(prop)) {
            delete obj[prop];
        }
    }
}

var map = new Object();
map['XKey1'] = "Value1";
map['XKey2'] = "Value2";
map['YKey3'] = "Value3";
map['YKey4'] = "Value4";
console.log(map);
removeKeyStartsWith(map, 'x', true);
console.log(map);

JS 小提琴演示

最后(至少现在)一种扩展Object原型的方法,允许用户搜索以给定字符串开头、以给定字符串结尾或(通过同时使用startsWith and endsWith给定字符串(with,或不区分大小写:

Object.prototype.removeIf = function (needle, opts) {
    var self = this,
        settings = {
            'beginsWith' : true,
            'endsWith' : false,
            'sensitive' : true
        };
    opts = opts || {};
    for (var p in settings) {
        if (settings.hasOwnProperty(p)) {
            settings[p] = typeof opts[p] == 'undefined' ? settings[p] : opts[p];
        }
    }
    var modifiers = settings.sensitive === true ? '' : 'i',
        regString = (settings.beginsWith === true ? '^' : '') + needle + (settings.endsWith === true ? '$' : ''),
        reg = new RegExp(regString, modifiers);
    for (var prop in self) {
        if (self.hasOwnProperty(prop) && reg.test(prop)){
            delete self[prop];
        }
    }
    return self;
};

var map = {
    'XKey1' : "Value1",
    'XKey2' : "Value2",
    'YKey3' : "Value3",
    'YKey4' : "Value4",
};

console.log(map);
map.removeIf('xkey2', {
    'beginsWith' : true,
    'endsWith' : true,
    'sensitive' : false
});
console.log(map);

JS 小提琴演示

参考:

于 2013-09-03T18:39:43.040 回答
3

您可以通过这种方式轻松获得它。

var map = new Object(); 
map['Key1'] = "Value1";
map['Key2'] = "Value2";
map['Key3'] = "Value3";
map['Key4'] = "Value4";
console.log(map);
delete map["Key1"];
console.log(map);

这是删除它的简单方法。

于 2015-08-07T05:37:28.457 回答
1

前提条件

假设您的原始输入:

var map = new Object();

map[XKey1] = "Value1";
map[XKey2] = "Value2";
map[YKey3] = "Value3";
map[YKey4] = "Value4";

并假设一个变量pattern将包含您想要过滤的键(例如,,,"X"... "Y""prefixSomething"

解决方案 1 - 使用 jQuery 过滤和创建新对象

var clone = {};

$.each(map, function (k, v) {
  if (k.indexOf(pattern) == 0) { // k not starting with pattern
    clone[k] = v;
  }
});

解决方案 2 - 使用纯 ECMAScript 并创建一个新对象

var clone = {};

for (var k in map) {
  if (map.hasOwnProperty(k) && (k.indexOf(pattern) == 0)) {
    clone[k] = map[k];
  }
}

解决方案 3 - 使用纯 ECMAScript 并使用源对象

for (var k in map) {
  if (map.hasOwnProperty(k) && (k.indexOf(pattern) == 0)) {
    delete map[k];
  }
}

或者,在现代浏览器中:

Object.keys(map).forEach(function (k) {
  if (k.indexOf(pattern) == 0) {
    delete map[k];
  }
});

更新 - 使用正则表达式进行模式匹配

k如果键以字母开头,而不是使用以下内容进行匹配:

k[0] == letter // to match or letter

或者如果键k以字符串开头,则匹配:

k.indexOf(pattern) // to match a string

您可以改用这个正则表达式:

new Regexp('^' + pattern).test(k)
// or if the pattern isn't variable, for instance you want
// to match 'X', directly use:
//   /^X/.test(k)
于 2013-09-03T18:48:07.900 回答