ホームページ > 記事 > ウェブフロントエンド > 1 レベルの抽象化: クリーンな関数の鍵
関数を見て、その複雑さに迷ったことはありませんか?クリーンなコードの基本原則を見てみましょう。関数は 1 つのレベルの抽象化のみを維持する必要があります。
Web アプリケーションでのユーザー作成の実際の例を次に示します。
// ❌ A function doing too many things at different abstraction levels function createUser(userData) { // Validate data if (!userData.email || !userData.email.includes('@')) { return 'Invalid email'; } if (userData.password.length < 8) { return 'Password too short'; } // Hash password const salt = generateSalt(); const hashedPassword = hashWithSalt(userData.password, salt); // Format user data const user = { email: userData.email.toLowerCase(), password: hashedPassword, salt: salt, createdAt: new Date() }; // Save to DB saveUserToDatabase(user); }
この関数は、さまざまなレベルの抽象化を組み合わせます:
単一レベルの抽象化原則に従ってリファクタリングしてみましょう:
// ✅ Clean version with one level of abstraction function createUser(userData) { const validationError = validateUserData(userData); if (validationError) return validationError; const securePassword = hashPassword(userData.password); const formattedUser = formatUserData(userData.email, securePassword); return saveUserToDatabase(formattedUser); } function validateUserData({ email, password }) { if (!email || !email.includes('@')) return 'Invalid email'; if (password.length < 8) return 'Password too short'; return null; } function hashPassword(password) { const salt = generateSalt(); return { hash: hashWithSalt(password, salt), salt }; } function formatUserData(email, securePassword) { return { email: email.toLowerCase(), password: securePassword.hash, salt: securePassword.salt, createdAt: new Date() }; }
関数を記述する場合:
覚えておいてください: 同じ関数内で「どのように」と「何を」を混在させる場合は、おそらく複数のレベルの抽象化を扱っていることになります。分割してください!
以上が1 レベルの抽象化: クリーンな関数の鍵の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。