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": [ "Женя" ]
}
*/