🌐 سایتسازهای ایستا (SSG)
سایتسازهای ایستا (Static Site Generators) یکی از محبوبترین روشهای ساخت وبسایتهای مدرن هستند. در این مقاله، به طور کامل با این ابزارها آشنا میشویم.
فهرست مطالب
SSG چیست؟
یک سایتساز ایستا (Static Site Generator) ابزاری است که فایلهای HTML، CSS و جاوااسکریپت وبسایت شما را قبل از اینکه کاربری از سایت بازدید کند، میسازد (در زمان ساخت یا build time).
📌 تعریف دقیق
interface StaticSiteGenerator {
// فایلهای ورودی
input: {
content: string[] // فایلهای مارکداون
templates: string[] // فایلهای قالب
assets: string[] // تصاویر، استایلها و...
}
// فرآیند ساخت
build: () => {
// ترکیب محتوا با قالبها
const pages = combine(content, templates)
// تولید فایلهای HTML نهایی
return pages.map(page => ({
html: generateHTML(page),
css: processCSS(page.styles),
js: processJS(page.scripts)
}))
}
// خروجی نهایی
output: StaticFiles
}نکته مهم
- برخلاف سایتهای پویا، در SSG هیچ پایگاه داده یا کد سمت سرور در زمان اجرا وجود ندارد.
نحوه عملکرد
🔄 چرخه کاری معمول
graph LR A[نوشتن محتوا] --> B[پردازش توسط SSG] B --> C[تولید HTML] C --> D[استقرار روی سرور] D --> E[دسترسی کاربر]
📝 مراحل دقیق
- نوشتن محتوا: شما محتوای خود را در فایلهای مارکداون مینویسید
- پردازش: SSG محتوا را با قالبها ترکیب میکند
- تولید فایلها: فایلهای HTML/CSS/JS نهایی تولید میشوند
- استقرار: فایلها روی سرور منتشر میشوند
- دسترسی: کاربران به سرعت بالا به محتوا دسترسی دارند
مزایای SSG
⚡ سرعت فوقالعاده
از آنجایی که صفحات از قبل ساخته شدهاند:
- نیازی به پردازش سمت سرور نیست
- پایگاه داده پرسوجو نمیشود
- فقط فایلها به کاربر تحویل داده میشوند
// مقایسه زمان پاسخدهی (میلیثانیه)
const responseTime = {
staticSite: 10, // SSG
dynamicSite: 200, // بدون کش
dynamicWithCache: 50, // با کش
}🔒 امنیت بالا
- حذف پایگاه داده = کاهش سطح حمله
- بدون کد سمت سرور پیچیده
- آسیبپذیریهای کمتر
| تهدید | سایت پویا | SSG |
|---|---|---|
| SQL Injection | ⚠️ خطر | ✅ ایمن |
| XSS | ⚠️ خطر | ⚠️ خطر کم |
| CSRF | ⚠️ خطر | ✅ ایمن |
💰 مقیاسپذیری و هزینه کم
const hostingCost = {
staticSite: 0, // رایگان (GitHub Pages)
dynamicSmall: 10, // $10/ماه
dynamicLarge: 1000, // $1000/ماه
staticWithCDN: 0, // رایگان (Netlify, Vercel)
}🎨 توسعه آسان
- کنترل نسخه با Git آسان است
- بدون نیاز به دپلوی پیچیده
- تست کردن سادهتر است
- محیط توسعه ساده
مقایسه با سایر روشها
📊 جدول مقایسه
| ویژگی | SSG | CMS | SPA |
|---|---|---|---|
| سرعت | ⚡⚡⚡ | ⚡ | ⚡⚡ |
| امنیت | 🔒🔒🔒 | 🔒 | 🔒🔒 |
| سئو | ✅✅✅ | ✅ | ⚠️ |
| هزینه | 💚💚💚 | 💚💚 | 💚💚 |
| دینامیک بودن | ⚠️ | ✅✅✅ | ✅✅ |
| پیچیدگی | 💚💚 | 💚 | 💚💚💚 |
💡 کدام برای شما مناسب است؟
def choose_method(your_needs):
if your_needs == "blog_or_portfolio":
return "SSG is perfect for you!"
elif your_needs == "ecommerce_with_dynamic_content":
return "Consider a CMS or hybrid approach"
elif your_needs == "complex_application":
return "SPA with SSR might be better"
else:
return "SSG is likely a good starting point"SSGهای محبوب
🚀 گزینههای پیشرو
1. Next.js
// Next.js with SSG
export async function getStaticProps() {
const posts = await getPosts()
return {
props: { posts },
revalidate: 60, // ISR - Incremental Static Regeneration
}
}- 🌟 محبوبترین انتخاب
- ✅ SSG + SSR + ISR
- 🎯 مبتنی بر React
- 📦 پکیج بزرگ اکوسیستم
2. Gatsby
// Gatsby data fetching
export const query = graphql`
query {
allMarkdownRemark {
edges {
node {
frontmatter {
title
date
}
}
}
}
}
`- 🌿 مبتنی بر React
- 📊 GraphQL داخلی
- 🖼️ بهینهسازی تصاویر خودکار
- 🔌 پلاگینهای غنی
3. Hugo
# Hugo config
baseURL: "https://example.com"
languageCode: "fa"
theme: "your-theme"- ⚡ سریعترین SSG
- 🚀 مبتنی بر Go
- 📝 مارکداون پیشفرض
- 🎚️ تنظیمات ساده
4. Jekyll
# Jekyll frontmatter
---
title: "My Post"
date: 2024-01-01
tags: [web, programming]
---- 💎 پشتیبانی GitHub Pages
- 💎 مبتنی بر Ruby
- 📝 ساده برای شروع
- 🌐 جامعه بزرگ
5. 11ty (Eleventy)
// Eleventy config
module.exports = function (eleventyConfig) {
eleventyConfig.addPassthroughCopy("./src/assets")
return {
dir: {
input: "src",
output: "public",
},
}
}- 🎚️ بسیار انعطافپذیر
- ⚙️ مبتنی بر Node.js
- 📚 ساده و سبک
- 🔄 قابلیت استفاده با هر تمپلیت
🌟 Quartz (این وبلاگ!)
// Quartz config
const config = {
pageTitle: "بلاگ من",
theme: {
typography: {
header: "Vazirmatn",
body: "Vazirmatn",
},
colors: colorPalettes.persianAzure,
},
}- 📚 مخصوص یادداشتهای Obsidian
- 🎨 طراحی زیبا
- 🌐 پشتیبانی از زبان فارسی
- 🔍 جستجوی قدرتمند
- 📊 گراف ارتباطی
نکته مهم
- این وبلاگ دقیقاً با Quartz ساخته شده است!
کدام SSG انتخاب کنیم؟
🎯 راهنمای انتخاب
graph TD A[شروع] --> B{نوع پروژه} B -->|وبلاگ ساده| C[Jekyll/Hugo] B -->|اپلیکیشن React| D[Next.js] B -->|سایت پیچیده| E[Gatsby] B -->|یادداشتهای Obsidian| F[Quartz] C --> G{آشنایی با برنامهنویسی} D --> G E --> G F --> G G -->|تازهکار| H[Jekyll/Quartz] G -->|با تجربه| I[Next.js/Gatsby]
✅ چکلیست انتخاب
- آیا با React آشنایی دارید؟ → Next.js/Gatsby
- آیا میخواهید یادداشتهای Obsidian را منتشر کنید؟ → Quartz
- آیا میخواهید سریعترین راه را بروید؟ → Hugo
- آیا از GitHub Pages استفاده میکنید؟ → Jekyll
- آیا انعطافپذیری میخواهید؟ → 11ty
مثال عملی: ساخت وبلاگ با SSG
📝 ساخت وبلاگ شخصی
# شروع با Next.js
npx create-next-app my-blog
cd my-blog
npm run dev
# یا با Hugo
hugo new site my-blog
cd my-blog
hugo server -D
# یا با Quartz
git clone https://github.com/jackyzha0/quartz
cd quartz
npm i
npx quartz build🎨 اضافه کردن محتوا
---
title: "اولین پست من"
date: 2024-01-15
tags: [یادگیری, برنامهنویسی]
---
# سلام دنیا!
این اولین پست وبلاگ من است که با SSG ساخته شده است.🚀 استقرار
# برای Next.js
npm run build
netlify deploy --prod
# برای Hugo
hugo
netlify deploy --prod
# برای Quartz
npx quartz build
npx quartz serveنقل قول
- سرعت ساده، ساده زیباست! - اصل طراحی
🌐 Static Site Generators (SSG)
Static Site Generators are one of the most popular methods for building modern websites. In this article, we’ll thoroughly explore these tools.
Table of Contents
- What is an SSG?
- How It Works
- Advantages of SSG
- Comparison with Other Methods
- Popular SSGs
- Which SSG to Choose?
What is an SSG?
A Static Site Generator is a tool that builds your website’s HTML, CSS, and JavaScript files before any user visits the site (at build time).
📌 Precise Definition
interface StaticSiteGenerator {
// Input files
input: {
content: string[] // Markdown files
templates: string[] // Template files
assets: string[] // Images, styles, etc.
}
// Build process
build: () => {
// Combine content with templates
const pages = combine(content, templates)
// Generate final HTML files
return pages.map(page => ({
html: generateHTML(page),
css: processCSS(page.styles),
js: processJS(page.scripts)
}))
}
// Final output
output: StaticFiles
}Important Note
- Unlike dynamic sites, SSGs have no database or server-side code at runtime.
How It Works
🔄 Typical Workflow
graph LR A[Write Content] --> B[Process by SSG] B --> C[Generate HTML] C --> D[Deploy to Server] D --> E[User Access]
📝 Detailed Steps
- Write Content: You write your content in Markdown files
- Processing: SSG combines content with templates
- Generate Files: Final HTML/CSS/JS files are generated
- Deploy: Files are published to server
- Access: Users access content at high speed
Advantages of SSG
⚡ Blazing Speed
Since pages are pre-built:
- No server-side processing needed
- No database queries
- Just delivering files to users
// Response time comparison (milliseconds)
const responseTime = {
staticSite: 10, // SSG
dynamicSite: 200, // Without cache
dynamicWithCache: 50, // With cache
}🔒 High Security
- Removing database = reduced attack surface
- No complex server-side code
- Fewer vulnerabilities
| Threat | Dynamic Site | SSG |
|---|---|---|
| SQL Injection | ⚠️ Risk | ✅ Secure |
| XSS | ⚠️ Risk | ⚠️ Low Risk |
| CSRF | ⚠️ Risk | ✅ Secure |
💰 Scalability & Low Cost
const hostingCost = {
staticSite: 0, // Free (GitHub Pages)
dynamicSmall: 10, // $10/month
dynamicLarge: 1000, // $1000/month
staticWithCDN: 0, // Free (Netlify, Vercel)
}🎨 Easy Development
- Easy version control with Git
- No need for complex deployment
- Easier testing
- Simple development environment
Comparison with Other Methods
📊 Comparison Table
| Feature | SSG | CMS | SPA |
|---|---|---|---|
| Speed | ⚡⚡⚡ | ⚡ | ⚡⚡ |
| Security | 🔒🔒🔒 | 🔒 | 🔒🔒 |
| SEO | ✅✅✅ | ✅ | ⚠️ |
| Cost | 💚💚💚 | 💚💚 | 💚💚 |
| Dynamic | ⚠️ | ✅✅✅ | ✅✅ |
| Complexity | 💚💚 | 💚 | 💚💚💚 |
💡 Which is Right for You?
def choose_method(your_needs):
if your_needs == "blog_or_portfolio":
return "SSG is perfect for you!"
elif your_needs == "ecommerce_with_dynamic_content":
return "Consider a CMS or hybrid approach"
elif your_needs == "complex_application":
return "SPA with SSR might be better"
else:
return "SSG is likely a good starting point"Popular SSGs
🚀 Leading Options
1. Next.js
// Next.js with SSG
export async function getStaticProps() {
const posts = await getPosts()
return {
props: { posts },
revalidate: 60, // ISR - Incremental Static Regeneration
}
}- 🌟 Most popular choice
- ✅ SSG + SSR + ISR
- 🎯 React-based
- 📦 Large package ecosystem
2. Gatsby
// Gatsby data fetching
export const query = graphql`
query {
allMarkdownRemark {
edges {
node {
frontmatter {
title
date
}
}
}
}
}
`- 🌿 React-based
- 📊 Internal GraphQL
- 🖼️ Automatic image optimization
- 🔌 Rich plugins
3. Hugo
# Hugo config
baseURL: "https://example.com"
languageCode: "fa"
theme: "your-theme"- ⚡ Fastest SSG
- 🚀 Go-based
- 📝 Default Markdown
- 🎚️ Simple configuration
4. Jekyll
# Jekyll frontmatter
---
title: "My Post"
date: 2024-01-01
tags: [web, programming]
---- 💎 GitHub Pages support
- 💎 Ruby-based
- 📝 Simple to start
- 🌐 Large community
5. 11ty (Eleventy)
// Eleventy config
module.exports = function (eleventyConfig) {
eleventyConfig.addPassthroughCopy("./src/assets")
return {
dir: {
input: "src",
output: "public",
},
}
}- 🎚️ Very flexible
- ⚙️ Node.js-based
- 📚 Simple and lightweight
- 🔄 Works with any template
🌟 Quartz (This Blog!)
// Quartz config
const config = {
pageTitle: "My Blog",
theme: {
typography: {
header: "Vazirmatn",
body: "Vazirmatn",
},
colors: colorPalettes.persianAzure,
},
}- 📚 Dedicated to Obsidian notes
- 🎨 Beautiful design
- 🌐 Persian language support
- 🔍 Powerful search
- 📊 Connection graph
Important Note
- This blog is built exactly with Quartz!
Which SSG to Choose?
🎯 Selection Guide
graph TD A[Start] --> B{Project Type} B -->|Simple Blog| C[Jekyll/Hugo] B -->|React App| D[Next.js] B -->|Complex Site| E[Gatsby] B -->|Obsidian Notes| F[Quartz] C --> G{Programming Knowledge} D --> G E --> G F --> G G -->|Beginner| H[Jekyll/Quartz] G -->|Experienced| I[Next.js/Gatsby]
✅ Selection Checklist
- Are you familiar with React? → Next.js/Gatsby
- Do you want to publish Obsidian notes? → Quartz
- Do you want the fastest route? → Hugo
- Do you use GitHub Pages? → Jekyll
- Do you want flexibility? → 11ty
Practical Example: Building a Blog with SSG
📝 Building a Personal Blog
# Start with Next.js
npx create-next-app my-blog
cd my-blog
npm run dev
# Or with Hugo
hugo new site my-blog
cd my-blog
hugo server -D
# Or with Quartz
git clone https://github.com/jackyzha0/quartz
cd quartz
npm i
npx quartz build🎨 Adding Content
---
title: "My First Post"
date: 2024-01-15
tags: [learning, programming]
---
# Hello World!
This is my first blog post built with SSG.🚀 Deployment
# For Next.js
npm run build
netlify deploy --prod
# For Hugo
hugo
netlify deploy --prod
# For Quartz
npx quartz build
npx quartz serveQuote
- Simplicity is the ultimate sophistication - Leonardo da Vinci