ES6 для цикла в значении ключа карты [дубликат]

Advanced Html Dom - это простая замена HTML DOM , которая предлагает один и тот же интерфейс, но это DOM-based, что означает, что ни одна из связанных проблем с памятью не возникает.

Он также имеет полную поддержку CSS, включая расширения jQuery .

105
задан thefourtheye 21 January 2016 в 02:23
поделиться

6 ответов

tl; dr

  1. В ECMAScript 5 это невозможно.
  2. В ECMAScript 2015 это возможно с Map s.
  3. В ECMAScript 2017 это было бы легко доступно.

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
163
ответ дан thefourtheye 24 August 2018 в 01:42
поделиться

Попробуйте следующее:

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"}
18
ответ дан Alexander Irbis 24 August 2018 в 01:42
поделиться

Попробуйте следующее:

var value;
for (var key in dictionary) {
    value = dictionary[key];
    // your code here...
}
6
ответ дан AMACB 24 August 2018 в 01:42
поделиться

с помощью swagger-ui.js

вы можете это сделать -

_.forEach({ 'a': 1, 'b': 2 }, function(n, key) {
    console.log(n, key);
 });
1
ответ дан deeshank 24 August 2018 в 01:42
поделиться

Вы можете сделать что-то вроде этого:

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
}
3
ответ дан Dhaval Chaudhary 24 August 2018 в 01:42
поделиться

Поскольку 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 мы можем перебирать каждую запись этого созданного массива
  • Поскольку мы гарантировали , что каждый из элементов с таким же итерационным массивом является другим массивом с двумя входами, мы можем использовать destructuring для прямого назначения переменных key и value к его первому и второму пункту.
18
ответ дан Loilo 24 August 2018 в 01:42
поделиться
Другие вопросы по тегам:

Похожие вопросы: