嘿,程式碼戰士和像素推動者! 👋 準備好將你的前端技能從零提升到英雄了嗎?您剛剛偶然發現了 Web 開發智慧的聖杯。繫好安全帶,因為我們即將踏上 8 項基本實踐之旅,將您的網站從“乏味”轉變為“令人興奮!”讓我們深入了解一下吧!
還記得一個月後你回到程式碼時發現它看起來像古老的象形文字嗎?是的,我們都去過那裡。這就是為什麼乾淨的程式碼是你新的最好的朋友。
將語意 HTML 視為網站的骨架。它為您的內容提供結構和意義。例如,不要在任何地方使用通用<div>
標籤,而是嘗試以下操作:
<article>
<header>
<h1>Why Cats Rule the Internet</h1>
</header>
<section>
<p>It's all about those whiskers...</p>
</section>
<footer>
<p>Written by: A Cat Lover</p>
</footer>
</article>
看看這清楚多少了?這就像為您的內容提供路線圖!
讓我們面對現實吧,如果管理不當,CSS 可能會成為一場噩夢。輸入 BEM(區塊、元素、修飾符)方法。就像 Marie Kondo 的樣式表一樣。看一下這個:
.card {}
.card__title {}
.card__button {}
.card__button--active {}
現在您可以一目了然地發現元素之間的關係。整潔吧?
在即時滿足的時代,速度慢的網站就是死網站。讓我們增強您的網站!
您是否知道圖像通常佔據頁面重量的大部分?是時候節食了!像 TinyPNG 這樣的工具可以創造奇蹟。我曾經將 5MB 的圖像縮小到 500KB,沒有任何明顯的品質損失。減少了 90%!
既然你可以偷懶,為什麼要一次載入所有內容呢?對影像實施延遲載入並觀察您的初始載入時間直線下降。這是一個使用本機loading
屬性的簡單範例:
<img src="cute-cat.jpg" loading="lazy" alt="A very cute cat">
隨著人們瀏覽從智慧手錶到智慧冰箱的各種內容,您的網站需要靈活。
Flexbox 就像佈局的瑜伽一樣 - 它使一切變得更加靈活。這是一個簡單的例子:
.container {
display: flex;
justify-content: space-between;
}
就像這樣,你就得到了一排均勻分佈的物品。魔法!
媒體查詢就像變色龍,允許您的網站適應不同的螢幕尺寸。這是一個有趣的例子:
@media (max-width: 600px) {
.container {
flex-direction: column;
}
}
現在,您的佈局在較小的螢幕上從行轉移到列。適應性最強!
想像嘗試閉上眼睛瀏覽網站。這對許多用戶來說是現實。讓我們的網站具有包容性!
確保所有互動元素都可以透過鍵盤存取。自己測試一下 - 拔掉滑鼠並嘗試使用您的網站。這是一次令人大開眼界的體驗!
ARIA 標籤就像是螢幕閱讀器的秘密耳語。它們提供了視覺線索不足的背景:
<button aria-label="Close dialog">X</button>
現在螢幕閱讀器使用者確切地知道「X」的意思!
讓我們來談談如何增強您的工作流程。因為人生對於重複性的任務來說太短暫了!
Git 就像你的程式碼的神奇時間機器。犯了一個錯誤?不用擔心!只需跳回之前的提交即可。您可以透過以下方式儲存您的工作:
git add .
git commit -m "Add awesome new feature"
git push origin main
現在您的變更是安全可靠的,可供協作或未來參考。
Sass 和 LESS 就像 CSS 的類固醇。變數、mixins、嵌套——天啊!看看這個 Sass 魔法:
$primary-color: #3498db;
.button {
background-color: $primary-color;
&:hover {
background-color: darken($primary-color, 10%);
}
}
繁榮!只需幾行即可進行動態顏色處理。試著使用純 CSS 來做到這一點!
JavaScript 是將靜態頁面轉變為互動式體驗的秘訣。明智地使用它!
還記得回調地獄嗎? Async/await 可以拯救你。看看這個乾淨、可讀的程式碼:
async function fetchUserData() {
try {
const response = await fetch('https://api.example.com/user');
const userData = await response.json();
console.log(userData);
} catch (error) {
console.error('Oops!', error);
}
}
不再有嵌套回調。未來的你會感謝你的!
擁抱最新的 JavaScript 功能。它們不僅僅是花哨的語法;它們使您的程式碼更具表現力和效率:
// Destructuring
const { name, age } = user;
// Template literals
console.log(`${name} is ${age} years old`);
// Arrow functions
const greet = name => `Hello, ${name}!`;
就好像您的程式碼進行了時尚改造!
框架可以真正改變遊戲規則。他們就像您擁有一支由專家開發人員組成的團隊!
React 席捲了網絡,這是有充分理由的。以下是其基於元件的優點:
function Welcome({ name }) {
return <h1>Hello, {name}!</h1>;
}
function App() {
return (
<div>
<Welcome name="Alice" />
<Welcome name="Bob" />
</div>
);
}
可重複使用的元件?查看。聲明式語法?查看。開發商幸福嗎?再檢查一遍!
最後但並非最不重要的一點是,我們來談談測試。它就像您的程式碼的安全網!
Jest 讓測試變得輕而易舉。這裡有一個簡單的測試來激發你的食慾:
test('adds 1 + 2 to equal 3', () => {
expect(sum(1, 2)).toBe(3);
});
執行您的測試,並觀察令人滿意的綠色複選標記的出現。奇怪的是,這會讓人上癮!
唷!我們已經涵蓋了很多內容,不是嗎?這 8 個最佳實踐是您實現卓越前端的路線圖。請記住,成為前端忍者是一個旅程,而不是目的地。不斷學習,不斷嘗試,最重要的是,享受樂趣!
你最喜歡的前端技巧是什麼?在下面發表評論,讓我們一起來極客吧!如果您發現本指南有幫助,請與其他開發人員分享。讓我們一起提高 Web 開發的門檻! 🚀
祝您編碼愉快,並祝您的控制台永遠沒有錯誤!
原文出處:https://dev.to/vyan/the-ultimate-frontend-developers-playbook-8-game-changing-practices-for-killer-websites-n1b