Advanced Html Dom - это простая замена HTML DOM , которая предлагает один и тот же интерфейс, но это DOM-based, что означает, что ни одна из связанных проблем с памятью не возникает.
Он также имеет полную поддержку CSS, включая расширения jQuery .
tl; dr
Map
s. ECMAScript 5:
Нет, это невозможно с объектами.
Вы должны либо итерации с помощью for..in
, либо Object.keys
, как это
for (var key in dictionary) {
// check if the property/key is defined in the object itself, not in parent
if (dictionary.hasOwnProperty(key)) {
console.log(key, dictionary[key]);
}
}
Примечание: Условие if
, указанное выше, необходимо, только если вы хотите итерировать свойства, которые являются dictionary
самим объектом. Поскольку for..in
будет перебирать все унаследованные перечислимые свойства.
Или
Object.keys(dictionary).forEach(function(key) {
console.log(key, dictionary[key]);
});
ECMAScript 2015
В ECMAScript 2015 вы можете использовать Map
объектов и итерации их с помощью Map.prototype.entries
. Пример цитаты из этой страницы,
var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");
var mapIter = myMap.entries();
console.log(mapIter.next().value); // ["0", "foo"]
console.log(mapIter.next().value); // [1, "bar"]
console.log(mapIter.next().value); // [Object, "baz"]
Или итерации с помощью for..of
, как это
'use strict';
var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");
for (const entry of myMap.entries()) {
console.log(entry);
}
Выход
[ '0', 'foo' ]
[ 1, 'bar' ]
[ {}, 'baz' ]
Или
for (const [key, value] of myMap.entries()) {
console.log(key, value);
}
Выход
0 foo
1 bar
{} baz
ECMAScript 2017
В ECMAScript 2017 будет введена новая функция Object.entries
. Вы можете использовать это для итерации объекта по своему желанию.
'use strict';
const object = {'a': 1, 'b': 2, 'c' : 3};
for (const [key, value] of Object.entries(object)) {
console.log(key, value);
}
Выход
a 1
b 2
c 3
Попробуйте следующее:
dict = {0:{1:'a'}, 1:{2:'b'}, 2:{3:'c'}}
for (var key in dict){
console.log( key, dict[key] );
}
0 Object { 1="a"}
1 Object { 2="b"}
2 Object { 3="c"}
Попробуйте следующее:
var value;
for (var key in dictionary) {
value = dictionary[key];
// your code here...
}
с помощью swagger-ui.js
вы можете это сделать -
_.forEach({ 'a': 1, 'b': 2 }, function(n, key) {
console.log(n, key);
});
Вы можете сделать что-то вроде этого:
dictionary = {'ab': {object}, 'cd':{object}, 'ef':{object}}
var keys = Object.keys(dictionary);
for(var i = 0; i < keys.length;i++){
//keys[i] for key
//dictionary[keys[i]] for the value
}
Поскольку ES2017 был стандартизован метод Object.entries()
, упомянутый в вопросе , первый комментарий :
for (const [ key, value ] of Object.entries(dictionary)) {
// do something with `key` and `value`
}
Объяснение:
Object.entries()
принимает объект, подобный { a: 1, b: 2, c: 3 }
, и превращает его в массив пар ключ-значение: [ [ 'a', 1 ], [ 'b', 2 ], [ 'c', 3 ] ]
for ... of
мы можем перебирать каждую запись этого созданного массива key
и value
к его первому и второму пункту.