-vf "drawtext=text=string1 string2 string3 string4 string5 string6 string7 :expansion=normal:fontfile=foo.ttf: y=h-line_h-10:x=(mod(5*n\,w+tw)-tw): fontcolor=white: fontsize=40: shadowx=2: shadowy=2"
viaffmpeg \
-i source_video.mp4 \
-vf........ (та длинная строка выше) \
-c:v libx264 \
-movflags +faststart \
-c:a aac \
-hide_banner \
output.mp4
(N * p1) % p2
14, 28, 42, 56, 70, 1, 15, 29, 43
const p1 = 97;
const p2 = 83;
const pass = [];
for (let n = 1; n < 10; n++) pass.push((n * p1) % p2);
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);
docker run -d -p 8080:80 nginx
http://localhost:8080
if( !e || !e.postData || !e.postData.contents) {
console.log({title:"Bad POST data", e: e});
return;
}
contents = JSON.parse(e.postData.contents);
if (! contents) {
console.log({title:"Contents failed to decode", e:e});
return;
}
const vk_user_id = contents.user_id; // может, так?
// посмотрите что выводит в лог
console.log(contents);
&&
он выше, чем у ||
. Поэтому выполняется так: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.https://www.googleapis.com/auth/youtube.force-ssl