ホームページ >ウェブフロントエンド >jsチュートリアル >コードを簡素化する JavaScript 関数 | JavaScript 関数 | JavaScript チュートリアル
JavaScript は関数型プログラミング言語であり、関数は重要な役割を果たします。これらを使用すると、再利用可能なコードをカプセル化し、特定のタスクを実行できます。ここでは、作業を楽にする関数の簡単な例をいくつか示します:
通常の機能
function sum(a, b) { return a + b; }
関数式
const sum = function (a, b) { return a + b; };
アロー関数
const sum = (a, b) => { return a + b; }; // OR const sum = (a, b) => a + b;
ジェネレーター関数
function* indexGenerator() { let index = 0; while (true) { yield index++; } } const g = indexGenerator(); console.log(g.next().value); // => 0 console.log(g.next().value); // => 1
1 から n までの数値の配列を作成します
const range = (n) => Array.from({ length: n }, (_, i) => i + 1); console.log(range(10)); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
ステップを使用して 1 から n までの数値の配列を作成します
const range = (n, step = 1) => Array.from({ length: n }, (_, i) => i * step); console.log(range(10, 2)); // [1, 3, 5, 7, 9]
配列を作成し、値を入力します
const fill = (len, value) => Array(len).fill(value); console.log(fill(3, 0)); // [0, 0, 0]
配列のシャッフル
const shuffleArray = (arr) => arr.sort(() => 0.5 - Math.random()); console.log(shuffleArray([1, 2, 3, 4])); // [3, 2, 1, 4]
配列から重複を削除
const removeDuplicated = (arr) => [...new Set(arr)]; console.log(removeDuplicated([1, 2, 3, 3, 4, 4, 5, 5, 6])); // Result: [ 1, 2, 3, 4, 5, 6 ] // OR const removeDuplicate = (arr) => Object.values(arr.reduce((a, b) => (a[b] ? a : { ...a, [b]: b }), {})); console.log(removeDuplicate([1, 2, 3, 3])); // Result: [ 1, 2, 3, ]
乱数を生成
const random = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min; console.log(random(1, 10)); // Result: 1 ~ 10
最大の数値を見つける
const findLargest = (arr) => arr.map((subArr) => Math.max(...subArr)); console.log( findLargest([ [4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1], ]) ); // [5, 27, 39, 1001]
最小の数値を見つける
const findSmallest = (arr) => arr.map((subArr) => Math.min(...subArr)); console.log( findSmallest([ [4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1], ]) ); // [1, 18, 32, 857]
配列からランダムな要素を選択します
const pick = (arr) => arr[Math.floor(Math.random() * arr.length)]; console.log(pick([1, 2, 3, 4])); // 2
配列をオブジェクトに変換する
const toObject = (arr) => ({ ...arr }); console.log(toObject(["a", "b"])); // { 0: 'a', 1: 'b' }
2 つの配列の共通部分を見つけます
const intersection = (arr1, arr2) => { const set = new Set(arr1); return arr2.filter((x) => set.has(x)); }; console.log(intersection([1, 2, 3], [2, 3, 4])); // [2, 3]
配列から偽の値を削除します
const compact = (arr) => arr.filter(Boolean); console.log(compact([0, 1, false, 2, "", 3, "a", "e" * 23, NaN, "s", 34])); // [1, 2, 3, 'a', 's', 34]
文字列を反転
const reverseString = (str) => str.split("").reverse().join(""); console.log(reverseString("hello")); // olleh
は文字列回文です
const isPalindrome = (str) => str === str.split("").reverse().join(""); console.log(isPalindrome("madam")); // true
オブジェクトが空かどうかを確認します
const isEmpty = (obj) => Object.keys(obj).length === 0; console.log(isEmpty({})); // true
1 か月の日数を確認します
const getDaysInMonth = (date) => new Date(date.getFullYear(), date.getMonth() + 1, 0).getDate(); console.log(getDaysInMonth(new Date())); // 31
ランダムな色を生成します
const getRandomColor = () => `#${Math.floor(Math.random() * 16777215).toString(16)}`; console.log(getRandomColor()); // #f0f0f0 // OR const randomHex = () => `#${Math.floor(Math.random() * 0xffffff) .toString(16) .padEnd(6, "0")}`; console.log(randomHex()); // #f0f0f0
このようなその他の関数については、Javascript Quick Functions GitHub リポジトリを確認してください。
以上がコードを簡素化する JavaScript 関数 | JavaScript 関数 | JavaScript チュートリアルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。