如何从以下映射中删除所有键/值对,其中键以 X 开头。
var map = new Object();
map[XKey1] = "Value1";
map[XKey2] = "Value2";
map[YKey3] = "Value3";
map[YKey4] = "Value4";
编辑
有没有办法通过正则表达式,可能使用 ^ 。类似于 map[^XKe],其中键以“Xke”而不是“X”开头
如何从以下映射中删除所有键/值对,其中键以 X 开头。
var map = new Object();
map[XKey1] = "Value1";
map[XKey2] = "Value2";
map[YKey3] = "Value3";
map[YKey4] = "Value4";
编辑
有没有办法通过正则表达式,可能使用 ^ 。类似于 map[^XKe],其中键以“Xke”而不是“X”开头
您可以使用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]==letter
和key.substr(0,3)==letter
我建议:
function removeKeyStartsWith(obj, letter) {
for (var prop in obj) {
if (obj.hasOwnProperty(prop) && prop[0] == letter){
delete obj[prop];
}
}
}
顺便说一句,使用 Object-literal 而不是构造函数通常更容易(并且似乎被认为是“更好的做法”),因此以下内容值得展示(即使出于某种原因,您更喜欢new Object()
语法:
var map = {
'XKey1' : "Value1",
'XKey2' : "Value2",
'YKey3' : "Value3",
'YKey4' : "Value4",
};
如果您真的想使用正则表达式(但为什么?),那么以下工作:
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);
最后(至少现在)一种扩展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);
参考:
您可以通过这种方式轻松获得它。
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);
这是删除它的简单方法。
假设您的原始输入:
var map = new Object();
map[XKey1] = "Value1";
map[XKey2] = "Value2";
map[YKey3] = "Value3";
map[YKey4] = "Value4";
并假设一个变量pattern
将包含您想要过滤的键(例如,,,"X"
... "Y"
)"prefixSomething"
。
var clone = {};
$.each(map, function (k, v) {
if (k.indexOf(pattern) == 0) { // k not starting with pattern
clone[k] = v;
}
});
var clone = {};
for (var k in map) {
if (map.hasOwnProperty(k) && (k.indexOf(pattern) == 0)) {
clone[k] = map[k];
}
}
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)