記事ディレクトリ
- 配列を生成する
- 配列をシャッフルする
- アレイの重複排除
- 複数の配列の交差
- 最大のインデックスを見つける
- 最小のインデックスを見つける
- 最も近い値を見つける
- 複数の配列を圧縮する
- 行列の行と列の交換
- 会話
- 電話番号の書式設定
- 余分なスペースを削除する
- 現在のページをリロードする
- ページの先頭までスクロールする
- 要素のスクロール
- 現在の IE ブラウザが
- 指定されたテキストから HTML を削除します
- リダイレクト
- テキストペースト
- 日付が今日かどうかを確認する
- 日付変換
- 秒換算
- 特定の年と月の最初の日を取得する
- 特定の年と月の最後の日を取得する
- 年、月、月の日数を取得する
- 非同期関数の判定
- 切り捨てられた数字
- 丸める
- ゼロパディング
- 無効な属性を削除する
- オブジェクトキーを反転する
- オブジェクトへの文字列
- 2 つのオブジェクトを比較します
- ランダムな色の生成
- カラーフォーマット変換
- ランダムなIPを取得する
- uuid
- クッキーを取得する
- 強制待機
配列を生成する
0 ~ 99 の配列スキーム 1を生成する必要がある場合
const createArr = (n) => Array.from(new Array(n), (v, i) => i)
const arr = createArr(100) // 0 - 99 数组
シナリオ 2
const createArr = (n) => new Array(n).fill(0).map((v, i) => i)
createArr(100) // 0 - 99数组
配列をシャッフルする
配列がある場合は、配列をシャッフルする必要があります
const randomSort = list => list.sort(() => Math.random() - 0.5)
randomSort([0,1,2,3,4,5,6,7,8,9]) // 随机排列结
アレイの重複排除
配列内のすべての重複要素を 1 つだけ保持する必要がある場合
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
複数の配列を圧縮する
複数の配列を 1 つに圧縮する必要がある場合
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'])
// [[1, 'a', 'A'], [2, 'b', 'B'], [3, 'c', 'C'], [4, 'd', '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],
] // ]
);
会話
10 進数を n 進数に変換するには、toString(n) を使用できます。
const toDecimal = (num, n = 10) => num.toString(n)
// 假设数字10要转换成2进制
toDecimal(10, 2) // '101
n 進数を 10 進数に変換するには、parseInt(num, n) を使用できます。
// 10的2进制为1010
const toDecimalism = (num, n = 10) => parseInt(num, n)
toDecimalism(1010, 2)
電話番号の書式設定
携帯電話番号をxxx-xxxx-xxxxの形式に変換する必要がある場合
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'
余分なスペースを削除する
テキスト内の複数のスペースを 1 つのスペースに結合する必要がある場合
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 = (text) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)
copy('你需要粘贴的文本')
日付が今日かどうかを確認する
const isToday = (date) => date.toISOString().slice(0, 10) === new Date().toISOString().slice(0, 10)
日付変換
日付をYYYY-MM-DD形式に変換する必要がある場合
const formatYmd = (date) => date.toISOString().slice(0, 10);
formatYmd(new Date())
秒換算
秒を hh:mm:ss 形式に変換する必要がある場合
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:0
特定の年と月の最後の日を取得する
特定の年と月の最後の日を取得する必要がある場合
const getLastDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth() + 1, 0);
getLastDate(new Date('2023-03-04')) // Fri Mar 31 2023 0
年、月、月の日数を取得する
特定の年の特定の月の合計日数を取得する必要がある場合
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
無効な属性を削除する
プロパティ値がnullまたは未定義のオブジェクト内のすべてのプロパティを削除する必要がある場合
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'}
オブジェクトへの文字列
'{name: “jack"}' などの文字列をオブジェクトに変換する必要がある場合、JSON.parse を直接使用するとエラーが報告されます。
const strParse = (str) => JSON.parse(str.replace(/(\w+)\s*:/g, (_, p1) => `"${
p1}":`).replace(/\'/g, "\""))
strParse('{name: "jack"}')
2 つのオブジェクトを比較します
2 つのオブジェクトを比較する必要がある場合、js equals はオブジェクトのアドレスが同じであるかどうかを判断することしかできず、アドレスが異なる場合、2 つのオブジェクトのキーと値のペアが一致しているかどうかを判断することはできません。
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'
カラーフォーマット変換
16進数の色を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('.');
uuid
IDを生成する必要がある場合
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')});