Promise.all(
id_contacts.map(id =>
axios
.post('api/add_contact', { id })
.then()
.catch(console.error)
)
)
.then(resultsArray => {
axios.post('api/bizproc', { contacts: resultsArray });
})
.catch(console.error);[warning] запросы контактов отправятся почти одновременно / параллельно, что может быть проблемой при большом их числе. Поэтому стоит продумать последовательные пачки параллельных запросов, если контактов там может быть больше, скажем, 10. this:const G = {
boo: function() {
console.log(this.x);
},
};
function A() {
let x = 'XXX';
const obj = { x, extraparams: { overwriteFunc: () => {}, }, };
// перезаписывание. Если typeof obj[prop] == 'function'
obj.extraparams.overwriteFunc = G.boo.bind(obj);
// вызов
obj.extraparams.overwriteFunc();
}
A(); // 'XXX' let и const объявляют переменные/константы с блочной областью видимости.let a делает её видимой только внутри фигурных скобок do { }.a. var e;
var r = t.length;
var n = '';
var i = 0;
var s = 0;
var a = 0;
// for (; i < r; ) {
while (i < r) {
s = t.charCodeAt(i);
if (s < 128) {
n += String.fromCharCode(s);
i++;
} else {
if (s > 191 && s < 224) {
// это заглавные кириллические буквы в Win1251
a = t.charCodeAt(i + 1);
// дальше код оборвался, приведён не полностью
}
}
}фрагмент кода приведёт не полный, поэтому и «распаковка» не полна. const lsKey = 'todo items';
// в самом начале посмотреть, есть ли сохранённые данные?
const data = JSON.parse(localStorage.getItem(lsKey)) || [];
// добавление нового
const item = { id: 123, name: 'aaa', title: 'bbb' };
data.push(item);
localStorage.setItem(lsKey, JSON.stringify(data)); if .. else if объединены проверки двух независимых переменных.if (Car.started === false && Car.fuel > 0) {
// и строго равно false, и fuel больше 0
} else if (Car.started && Car.fuel <= 0) {
// сюда попадают не прошедшие первый if
// и к тому же соответствующие второй проверке started && fuel <= 0
}
// никуда не попадут:
// Car.started = undefined (не строго false, но и не переводится в true
// Car.started === false, но и fuel > 0 swa() забыли привести, как вы начали её писать?target – элемент, по которому кликнули. В данном случае это тег <a>parent) – это div. А в нём уже найти элемент H3:const title = event.target.parent.querySelector('h3').innerText; redraw_table() в коллбэке по успешному завершению выполнения запроса. id как особый, и добавлять к нему в массив match другие похожие — все id с одинаковыми прочими значениями равноправны. Поэтому предлагаю как результат просто массивы, где собраны id с совпадающими свойствами.id, упорядоченных по алфавиту, и значений. Этот отпечаток будет одинаков у совпадающих объектов, несмотря на разные id (и разный порядок ключей).{ id, hash }, затем составляем «словарь», где ключи – хэши, а значения – Set'ы с id, у которых оказался одинаковый хэш. Set'ы – чтобы не повторялись одинаковые id.const arr = [
{ id: 1, we: 'cn', le: null },
{ id: 2, le: null, we: 'cn' },
{ id: 3, we: 'cn', le: 'car' },
{ id: 1, we: 'cn', le: null },
];
const dict = arr
.map(({ id, ...obj }) => {
const keys = Object.keys(obj).sort();
const ordered = keys.reduce((acc, c) => {
acc[c] = obj[c];
return acc;
}, {});
return { id, hash: JSON.stringify(ordered) };
})
.reduce((acc, c) => {
(acc[c.hash] ??= new Set()).add(c.id);
return acc;
}, {});
Object.values(dict).map(s => [...s]); // [ [1, 2], [3] ] index.js, в который таки прописать каждый файл в папке.// papka/index.js
import a from './a';
import b from './b';
// ...
export { a, b, };// main.js
import * as Papka from '/papka';
const { a, b } = Papka;
console.log(a, b);
// или
Object.entries(Papka).forEach(([key, value]) => console.log(key, value)); const get_element_list = id => {
return axios({
url: `${url_hook}/lists.element.get.json`,
method: 'post',
data: {
IBLOCK_TYPE_ID: 'lists',
IBLOCK_ID: 17,
filter: {
PROPERTY_70: 1,
PROPERTY_74: id,
},
},
}).then(response => {
const result = response.data.result[0];
console.log(result, response.status, response.data); // посмотрите, что тут
});
}; localStorage. id. На случай, если их перемешают иначе, или добавится новая — полагаться только на порядковый номер в коллекции, i, не годится: сейчас на 3-м месте одна кнопка, завтра окажется другая, а мы для неё запомнили включённое состояние.id. Кнопка может быть добавлена или не-добавлена в избранное. Булево значение: true или false. Запоминать будем набор пар ключ-значение. Ключ id, значение true/false. Что-то типа { "abc123": true, "xyz789": false, }const mostLeastAndTheRest = names => {
const dict = names.reduce((acc, name) => ((acc[name] ??= 0), acc[name]++, acc), {});
// { "Женя": 3, "Иван": 1, "Виктор": 4, "Константин": 1 }
const values = Object.values(dict);
const max = Math.max(...values);
const min = Math.min(...values);
const entries = Object.entries(dict);
const winners = entries.filter(([_, value]) => value === max).map(([key, _]) => key);
const losers = entries.filter(([_, value]) => value === min).map(([key, _]) => key);
const rest = Object.keys(dict).filter(name => !winners.includes(name) && !losers.includes(name));
return { winners, losers, rest };
};
mostLeastAndTheRest(['Женя', 'Женя', 'Иван', 'Женя', 'Виктор', 'Виктор', 'Константин', 'Виктор', 'Виктор']);
/*
{
"winners": [ "Виктор" ],
"losers": [ "Иван", "Константин" ],
"rest": [ "Женя" ]
}
*/