reduce()
объект триггеров с тремя ключами, по каждому из ключевых слов. Перед вставкой очередной пары с ключом из триггеров, переводить его в true. Если он до этого уже включён — значит, пора вставлять новый объект для заполнения.const data = [
{name: "name", value: "John"},
{name: "last_name", value: "Snow"},
{name: "father_name", value: ""},
{name: "name", value: "Tony"},
{name: "last_name", value: "Stark"},
{name: "father_name", value: ""},
{name: "other_field", value: "damn"},
];
data.reduce((acc, c) => {
if (true === acc.triggers[c.name]) {
Object.keys(acc.triggers).forEach((key) => acc.triggers[key] = false);
acc.arr.push({});
}
if (c.name in acc.triggers) acc.triggers[c.name] = true;
acc.arr[acc.arr.length - 1][c.name] = c.value;
return acc;
}, {
triggers: {
"name": false,
"last_name": false,
"father_name": false,
},
arr: [{}],
}).arr;
/*
[
{
"name": "John",
"last_name": "Snow",
"father_name": ""
},
{
"name": "Tony",
"last_name": "Stark",
"father_name": "",
"other_field": "damn"
}
]
*/
var foo;
var foo = 1; // можно стереть
function bar() {
var foo; // всплыло сюда. Этот foo – иной, чем верхний foo!
if (!foo) { // тут foo undefined, !foo === true
foo = 10; // выполняется, назначается 10
}
console.log(foo); // вывели 10
}
bar(); //--> 10
function filterByCategory(cat) {
const dataCats = $("[data-cat]");
if (cat == 'all') {
dataCats.removeClass("hide");
} else {
dataCats.each(function () {
if (cat == $(this).data('cat')) {
$(this).removeClass('hide');
} else {
$(this).addClass('hide');
}
});
}
}
$(function () {
const worksSlider = $('[data-slider="slick"]');
/* Filter
=====================*/
const filter = $("[data-filter]");
filter.on("click", function (event) {
event.preventDefault();
const cat = $(this).data('filter');
filterByCategory(cat);
});
filterByCategory('female');
});
re
с флагом g
сохраняет состояние – свойство lastIndex
– позицию, где последний раз был найден результат. И дальше ищет начиная с этого места.for (var i=0; i<10;i++) {
+ re.lastIndex = 0; // каждый раз начинать искать с 0
var txt = re.exec(a);
&&
он выше, чем у ||
. Поэтому выполняется так:pin.length == 4 || (pin.length == 6 && a == 1)
a
с 1
: т.к. метод test()
возвращает Boolean true
или false
, можно прямо проверятьif (a && (pin.length === 4 || pin.length === 6)) {
const validatePIN = (pin) => /^\d{4}(\d{2})?$/.test(pin);
Между началом и концом строки должно быть 4 цифры и, опционально, ещё 2.id
, после которого брать новости. Как получили ответ – показали принятые новости и сохранили в переменной id
для следующего запроса.'AND feed.time_update < ' . (int) $lastFeed['time_update']
оч. плохая практика склеивать строку запроса. Используйте биндинг параметров, что-то типа:$stmt = $conn->prepare("SELECT ..... AND feed.time_update < ?");
$stmt->bind_param($lastFeed['time_update']);
$stmt->execute();
$result = $stmt->fetchAll();
example.com/?text=%D0%A2%D0%B5%D0%BA%D1%81%D1%82
num=%D0%9D%D0%BE%D0%BC%D0%B5%D1%80
old=%D0%94%D0%B0%D0%BD%D0%BD%D1%8B%D0%B5
{"data":{"text":"Текст","num":"Номер","old":"Данные"}
var
больше не стоит использовать, вообще. Только let
и const
.var a = 5;
— тут происходит 2 вещи: function a()
уплывает наверх выше назначения a = 5
, которое оказывается после всех деклараций. Можно даже так:function a() {
return 10;
}
a = 5;
Это, по сути, и происходит в 1-м примере.