Множество

Создать массив

Когда вам нужно сгенерировать массив от 0 до 99
Решение 1

const createArr = (n) => Array.from(new Array(n), (v, i) => i)
const arr = createArr(100) // 0 - 99 array

Сценарий 2

const createArr = (n) => new Array(n).fill(0).map((v, i) => i)
createArr(100) // 0 - 99 array

Перетасовать массив

Когда у вас есть массив, вам нужно перетасовать массив

const randomSort = list => list.sort(() => Math.random() - 0.5)
randomSort([0,1,2,3,4,5,6,7,8,9]) // Randomize results

Дедупликация массива

Когда вам нужно сохранить все повторяющиеся элементы в массиве только один

const removeDuplicates = list => [...new Set(list)]
removeDuplicates([0, 0, 2, 4, 5]) // [0,2,4,5]

Пересечение нескольких массивов

Когда вам нужно взять пересечение нескольких массивов

const intersection = (a, ...arr) => [...new Set(a)].filter((v) => arr.every((b) => b.includes(v)))
intersection([1, 2, 3, 4], [2, 3, 4, 7, 8], [1, 3, 4, 9])
// [3, 4]

Найдите максимальный индекс

Но вам нужно найти индекс максимального значения в массиве

const indexOfMax = (arr) => arr.reduce((prev, curr, i, a) => (curr > a[prev] ? i : prev), 0);
indexOfMax([1, 3, 9, 7, 5]); // 2

Найдите минимальный индекс

Когда вам нужно найти индекс минимального значения в массиве

const indexOfMin = (arr) => arr.reduce((prev, curr, i, a) => (curr < a[prev] ? i : prev), 0)
indexOfMin([2, 5, 3, 4, 1, 0, 9]) // 5

Найдите ближайшее значение

Когда вам нужно найти ближайшее значение в массиве

const closest = (arr, n) => arr.reduce((prev, curr) => (Math.abs(curr - n) < Math.abs(prev - n) ? curr : prev))
closest([29, 87, 8, 78, 97, 20, 75, 33, 24, 17], 50) // 33

Сжать несколько массивов

Когда вам нужно сжать несколько массивов в один

const zip = (...arr) => Array.from({ length: Math.max(...arr.map((a) => a.length)) }, (_, i) => arr.map((a) => a[i]))
zip([1,2,3,4], ['a', 'b', 'c', 'd'], ['A', 'B', 'C', 'D'])

Замена строк и столбцов матрицы

Когда вам нужно поменять местами строки и столбцы матрицы

const transpose = (matrix) => matrix[0].map((col, i) => matrix.map((row) => row[i]));
transpose(
    [              // [
        [1, 2, 3], //      [1, 4, 7],
        [4, 5, 6], //      [2, 5, 8],
        [7, 8, 9], //      [3, 6, 9],
     ]             //  ]
 ); 

Цифровое преобразование

Преобразование

Чтобы преобразовать десятичное число в n-арное, вы можете использовать toString(n)

const toDecimal = (num, n = 10) => num.toString(n) 
// Suppose the number 10 is to be converted to binary
toDecimal(10, 2) // '1010'

Чтобы преобразовать n-арное в десятичное, вы можете использовать parseInt(num, n)

// The binary system of 10 is 1010
const toDecimalism = (num, n = 10) => parseInt(num, n)
toDecimalism(1010, 2)

Обычный

Форматирование номера телефона

Когда вам нужно отформатировать номер мобильного телефона в виде ххх-хххх-хххх

const formatPhone = (str, sign = '-') => str.replace(/(\W|\s)/g, "").split(/^(\d{3})(\d{4})(\d{4})$/).filter(item => item).join(sign)
formatPhone('13123456789') // '131-2345-6789'
formatPhone('13 1234 56 789', ' ') // '131 2345 6789'

Удалить лишние пробелы

Когда вам нужно объединить несколько пробелов в фрагменте текста в один пробел

const setTrimOut = str => str.replace(/\s\s+/g, ' ')
const str = setTrimOut('hello,   jack') // 

Интернет

Перезагрузить текущую страницу

const reload = () => location.reload();
reload()

Прокрутите вверх страницы

Если вам нужно перевернуть страницу на самый верх

const goToTop = () => window.scrollTo(0, 0);
goToTop()

Прокрутка элемента

Если вы хотите плавно прокрутить элемент до начала видимой области

const scrollToTop = (element) =>
  element.scrollIntoView({ behavior: "smooth", block: "start" })
scrollToTop(document.body)

Если вы хотите плавно прокрутить элемент до конца видимой области

const scrollToBottom = (element) =>
  element.scrollIntoView({ behavior: "smooth", block: "end" })
  scrollToBottom(document.body)

Проверьте, является ли текущий браузер IE

const isIE = !!document.documentMode;

удалить HTML из заданного текста

Когда вам нужно отфильтровать все теги в определенном тексте

const stripHtml = (html) => new DOMParser().parseFromString(html, 'text/html').body.textContent || '';
stripHtml('<div>test</div>') // 'test'

перенаправить

когда вам нужно перейти на другие страницы

const goTo = (url) => (location.href = url);

Вставка текста

Когда нужно скопировать текст в буфер обмена

const copy = (test) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)
copy('some text you want copy')

Дата

Проверить, сегодня ли дата

const isToday = (date) => date.toISOString().slice(0, 10) === new Date().toISOString().slice(0, 10)

Преобразование даты

Когда вам нужно преобразовать дату в формат ГГГГ-ММ-ДД

const formatYmd = (date) => date.toISOString().slice(0, 10);
formatYmd(new Date())

Преобразование секунд

Когда вам нужно преобразовать секунды в формат чч:мм:сс

const formatSeconds = (s) => new Date(s * 1000).toISOString().substr(11, 8)
formatSeconds(200) // 00:03:20

Получить первый день определенного года и месяца

Когда вам нужно получить первый день определенного года и месяца

const getFirstDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth(), 1);
getFirstDate(new Date('2022-04')) // Fri Apr 01 2022 00:00:00 GMT+0800 

Получить последний день определенного года и месяца

Когда вам нужно получить последний день определенного года и месяца

const getLastDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth() + 1, 0);
getLastDate(new Date('2023-03-04')) // Fri Mar 31 2023 00:00:00 GMT+0800 

Получить количество дней в году, месяце и месяце

Когда вам нужно получить общее количество дней в определенном месяце определенного года

const getDaysNum = (year, month) => new Date(year, month, 0).getDate()  
const day = getDaysNum(2024, 2) // 29

Функция

Оценка асинхронной функции

Определить, является ли функция асинхронной функцией

const isAsyncFunction = (v) => Object.prototype.toString.call(v) === '[object AsyncFunction]'
isAsyncFunction(async function () {}); // true

Число

Усеченные числа

Когда вам нужно обрезать некоторые числа после запятой без округления

const toFixed = (n, fixed) => `${n}`.match(new RegExp(`^-?\d+(?:.\d{0,${fixed}})?`))[0]
toFixed(10.255, 2) // 10.25

Округление

Когда вам нужно обрезать некоторые числа после запятой и выполнить округление

const round = (n, decimals = 0) => Number(`${Math.round(`${n}e${decimals}`)}e-${decimals}`)
round(10.255, 2) // 10.26

Нулевое заполнение

Когда вам нужно заполнить переднюю часть нулями, когда число num меньше, чем len цифр

const replenishZero = (num, len, zero = 0) => num.toString().padStart(len, zero)
replenishZero(8, 2) // 08

Объект

Удалить недопустимые атрибуты

Когда вам нужно удалить все свойства в объекте, значения свойств которого равны нулю или не определены

const removeNullUndefined = (obj) => Object.entries(obj).reduce((a, [k, v]) => (v == null ? a : ((a[k] = v), a)), {});
removeNullUndefined({name: '', age: undefined, sex: null}) // { name: '' }

Инвертировать ключи объекта

Когда вам нужно обменяться парами ключ-значение объектов

const invert = (obj) => Object.keys(obj).reduce((res, k) => Object.assign(res, { [obj[k]]: k }), {})
invert({name: 'jack'}) // {jack: 'name'}

Другой

Сравнивает два объекта

Когда вам нужно сравнить два объекта, js equals может только судить о том, совпадают ли адреса объектов, и не может судить о том, согласованы ли пары ключ-значение двух объектов, когда адреса разные.

const isEqual = (...objects) => objects.every(obj => JSON.stringify(obj) === JSON.stringify(objects[0]))
isEqual({name: 'jack'}, {name: 'jack'}) // true
isEqual({name: 'jack'}, {name: 'jack1'}, {name: 'jack'}) // false

Генерация случайных цветов

когда вам нужно получить случайный цвет

const getRandomColor = () => `#${Math.floor(Math.random() * 0xffffff).toString(16)}`
getRandomColor() // '#4c2fd7'

Преобразование цветового формата

Когда вам нужно преобразовать шестнадцатеричный цвет в rgb

const hexToRgb = hex => hex.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, (_, r, g, b) => `#${r}${r}${g}${g}${b}${b}`).substring(1).match(/.{2}/g).map((x) => parseInt(x, 16));
hexToRgb('#00ffff'); // [0, 255, 255]
hexToRgb('#0ff'); // [0, 255, 255]

Получить случайный ip

когда вам нужно сгенерировать IP-адрес

const randomIp = () =>
    Array(4)
        .fill(0)
        .map((_, i) => Math.floor(Math.random() * 255) + (i === 0 ? 1 : 0))
        .join('.');

Уид

когда вам нужно сгенерировать идентификатор

const uuid = (a) => (a ? (a ^ ((Math.random() * 16) >> (a / 4))).toString(16) : ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, uuid))
uuid()

Получить куки

Когда вам нужно преобразовать cookie в объект

const getCookie = () => document.cookie
    .split(';')
    .map((item) => item.split('='))
    .reduce((acc, [k, v]) => (acc[k.trim().replace('"', '')] = v) && acc, {})
getCookie()

Обязательное ожидание

Когда вам нужно подождать какое-то время, но вы не хотите писать в функцию setTimeout, вызывая ад обратного вызова

const sleep = async (t) => new Promise((resolve) => setTimeout(resolve, t));
sleep(2000).then(() => {console.log('time')});








Дополнительные материалы на PlainEnglish.io.

Подпишитесь на нашу бесплатную еженедельную рассылку новостей. Подпишитесь на нас в Twitter, LinkedIn, YouTube и Discord .