Rumah >hujung hadapan web >tutorial js >Satu Tahap Abstraksi: Kunci kepada Fungsi Bersih
Pernah melihat fungsi dan rasa hilang dalam kerumitannya? Mari kita terokai prinsip asas kod bersih: fungsi harus mengekalkan hanya satu tahap abstraksi.
Berikut ialah contoh dunia sebenar penciptaan pengguna dalam aplikasi 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); }
Fungsi ini mencampurkan tahap abstraksi yang berbeza:
Mari kita memfaktorkannya mengikut tahap tunggal prinsip abstraksi:
// ✅ 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() }; }
Apabila menulis fungsi:
Ingat: Jika anda mencampurkan "bagaimana" dan "apa" dalam fungsi yang sama, anda mungkin berurusan dengan berbilang tahap abstraksi. Pisahkan mereka!
Atas ialah kandungan terperinci Satu Tahap Abstraksi: Kunci kepada Fungsi Bersih. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!