const getSome = (arr) => arr.filter(() => Math.random() >= 0.5);
function noRepeats(str) {
const length = str.length;
let result;
search:
for (let i = 2; i < length; i++) {
if (length % i) continue;
const slen = length / i;
const sample = str.substr(0, slen);
for (let j = 1; j < i; j++) {
if (sample !== str.substr(j * slen, slen))
continue search;
}
result = sample;
}
return result.length ? result : str;
}
querySelector()
возвращает только один, первый найденный элемент. А надо все. Это делает querySelectorAll()const links = document.querySelectorAll('.header__link');
window.addEventListener('scroll', function(){
links.forEach((el) => el.classList.toggle('cactive', pageYOffset > 0));
});
elem = false;
– в переменной же лежит элемент, с которым работатьfunc
без скобок. Иначе слушать будет результат вызова ф-ииelem.checked == true
– должно быть именно ==
. У вас один знак равенства, он присваивает значение.const elem = document.getElementById('elem');
const btn = document.getElementById('btn');
const p = document.getElementById('p');
btn.addEventListener('click', () => p.innerText = elem.checked ? 'Привет' : 'Пока!');
const event = new Event('added_to_cart');
// слушать это событие
elem.addEventListener('added_to_cart', function (e) { /* ... */ }, false);
// вызвать это событие
elem.dispatchEvent(event);
delete()
для удаления параметра. В итоге из URL получим новую адресную строку без лишнего параметра.const url = new URL(document.location);
const searchParams = url.searchParams;
searchParams.delete("test"); // удалить параметр "test"
window.history.pushState({}, '', url.toString());
Article.bind, .call, .length
– небольшой список зарезервированных свойств.function addLocalProperty(value) {
let property = value;
return function() {
property++;
console.log(property);
}
}
const fn = addLocalProperty(0);
fn(); // 1
fn(); // 2