FA-TOOLS — Header Component

آموزش ساخت اسکلتون اسکرین (Skeleton Screen) برای لودینگ ظریف محتوا

سلام رفیق برنامه‌نویس! تا حالا شده منتظر لود شدن یه صفحه باشی و فقط یه صفحه سفید یا یه اسپینر خسته‌کننده رو ببینی؟ تجربه‌ی خوبی نیست، درسته؟ امروزه دیگه زمان اون رسیده که با این شیوه‌های قدیمی خداحافظی کنیم و لودینگ محتوامون رو با یه روش خیلی شیک‌تر و کاربرپسندتر هندل کنیم: اسکلتون اسکرین (Skeleton Screen). این تکنیک جالب کمک می‌کنه تا کاربر حس نکنه صفحه داره دیر بارگظاری میشه و بجاش یه حس دلنشین و ظریف از آماده شدن محتوا رو بهش هدیه می‌کنی. آماده‌ای که اینترفیس کاربری (UI) پروژه‌هات رو متحول کنی؟ پس بزن بریم تا قدم به قدم یاد بگیریم چطور این رو بسازیم و یه تجربه کاربری عالی (UX) رقم بزنیم. ضمناً، اگه دنبال کدهای آماده و ابزارهای توسعه‌ی حرفه‌ای هستی، حتماً یه سر به فروشگاه ابزارهای ما بزن؛ کلی چیز به درد بخور اونجا پیدا می‌کنی! برای مشاوره فوری هم می‌تونی با شماره 09202232789 تماس بگیری.

🚀 نقشه راه: ساخت اسکلتون اسکرین در یک نگاه

۱. تعریف و چرایی؟

  • مقدمه‌ای بر Skeleton Screen
  • چرا بهش نیاز داریم؟ بهبود UX و درک عملکرد

۲. ساختار HTML

  • ایجاد طرح کلی با تگ‌های HTML
  • جایگذاری با محتوای واقعی

۳. استایل‌دهی CSS

۴. منطق JS

با این چهار قدم ساده، لودینگ پروژه‌ت رو جذاب‌تر و حرفه‌ای‌تر کن!

اسکلتون اسکرین چیه و چرا باید ازش استفاده کنیم؟

اسکلتون اسکرین، یا همون صفحه اسکلت، یه تکنیک تو طراحی UI هست که به جای نشون دادن یه صفحه خالی یا یه لودینگ اسپینر ساده، یه نسخه‌ی کم‌رنگ و استاتیک از طرح کلی محتوایی که قراره بارگذاری بشه رو نمایش می‌ده. فکر کن داری یه مقاله می‌خونی؛ وقتی صفحه لود میشه، قبل از اینکه متن و عکس‌ها بیان، یه سری بلوک‌های مستطیلی خاکستری رو می‌بینی که جای تیترها، پاراگراف‌ها و تصاویر رو نشون می‌دن. اینجوری کاربر از قبل یه دید کلی از چیدمان صفحه پیدا می‌کنه و حس نمی‌کنه که اینترنتش قطع شده یا برنامه هنگ کرده.

چرا از Skeleton Screen استفاده کنیم؟ مزایا و فایده‌هاش

استفاده از اسکلتون اسکرین کلی مزیت داره که هم برای کاربر خوبه و هم برای کسب‌وکار و سئو سایتت. بیا چندتا از مهم‌تریناشو با هم مرور کنیم:

  • تجربه کاربری بهتر (UX): مهمترین دلیل! کاربر دیگه با صفحه خالی روبرو نمیشه. یه پیش‌نمایش از محتوا بهش نشون میدی که باعث میشه حس کنه اپلیکیشن یا سایتت سریع‌تره، حتی اگه زمان لودینگ همون باشه. این بهش “Perceived Performance” یا “عمل کرد محسوس” میگن.
  • کاهش نرخ پرش (Bounce Rate): وقتی کاربر انتظارش از صفحه برآورده میشه و چیزی برای دیدن داره، کمتر پیش میاد که صفحه رو سریع ببنده و برگرده تو گوگل.
  • افزایش زمان ماندگاری کاربر: کاربر بیشتر تو سایتت می‌مونه چون احساس بهتری داره و می‌دونه محتوا داره بارگذاری میشه.
  • حس حرفه‌ای بودن: به پروژه‌ت یه ظاهر مدرن و حرفه‌ای میده. شرکت‌های بزرگی مثل فیسبوک، لینکدین، و یوتیوب از این روش استفاده می‌کنن.
  • واکنش گریی (Responsiveness) بهتر: از اونجایی که ساختار اسکلتون معمولاً ساده است، روی هر دستگاهی از موبایل و تبلت گرفته تا لپ‌تاپ و تلویزیون، یه تجربه لودینگ مناسبی رو ارائه میده.

آموزش ساخت اسکلتون اسکرین: گام به گام

حالا که می‌دونیم چرا اسکلتون اسکرین عالیه، وقتشه که آستین بالا بزنیم و خودمون یکی بسازیم. این کار رو تو سه مرحله اصلی انجام میدیم: ساختار HTML، استایل‌دهی CSS و منطق JavaScript.

۱. ساختار HTML: اسکلت اصلی محتوا

اولین قدم، ساخت یه ساختار ساده HTML هست که شبیه به محتوای نهایی ما باشه. مثلاً اگه یه کارت محصول داریم که شامل عکس، عنوان، و توضیحاته، یه Skeleton هم با همین سه بخش می‌سازیم. به جای محتوای واقعی، از `div`های خالی با کلاس‌های مناسب استفاده می‌کنیم.

🔗 کپی کد


<!-- محتوای واقعی (مخفی تا زمان لود کامل) -->
<div class="content-wrapper" id="actual-content" style="display: none;">
    <div class="card">
        <img src="product-image.jpg" alt="نام محصول" class="card-image">
        <h2 class="card-title">نام محصول شگفت‌انگیز</h2>
        <p class="card-description">این یک توضیحات کامل برای محصول است که جزئیات و ویژگی‌های آن را بیان می‌کند.</p>
        <button class="card-button">خرید</button>
    </div>
</div>

<!-- اسکلتون اسکرین (نمایش تا زمان لود محتوا) -->
<div class="skeleton-wrapper" id="skeleton-content">
    <div class="card-skeleton">
        <div class="skeleton-image"></div>
        <div class="skeleton-title"></div>
        <div class="skeleton-description"></div>
        <div class="skeleton-button"></div>
    </div>
    <!-- می‌تونی چندتا کارت اسکلتون دیگه هم اینجا اضافه کنی -->
    <div class="card-skeleton">
        <div class="skeleton-image"></div>
        <div class="skeleton-title"></div>
        <div class="skeleton-description"></div>
        <div class="skeleton-button"></div>
    </div>
</div>

<script>
function copyCode(buttonElement) {
    const codeBlock = buttonElement.nextElementSibling;
    const range = document.createRange();
    range.selectNode(codeBlock);
    window.getSelection().removeAllRanges();
    window.getSelection().addRange(range);
    try {
        document.execCommand('copy');
        buttonElement.textContent = '✅ کپی شد!';
        setTimeout(() => {
            buttonElement.textContent = '🔗 کپی کد';
        }, 2000);
    } catch (err) {
        console.error('Failed to copy code: ', err);
        buttonElement.textContent = '❌ خطا در کپی!';
    }
    window.getSelection().removeAllRanges();
}
</script>

همونطور که می‌بینی، ما یه `div` داریم برای محتوای اصلی که فعلاً مخفیه (`display: none;`) و یه `div` دیگه برای Skeleton که قراره اولش نمایش داده بشه. هر کدوم از این بلاک‌ها هم یه ساختار کارتی دارن. این یه نمونه‌ی پایه است؛ تو می‌تونی ساختار اسکلت رو دقیقاً منطبق با محتوای صفحه‌ی خودت طراحی کنی. اگه با وردپرس کار می‌کنی، می‌تونی از فیلدهای سفارشی (Custom Fields) یا افزونه‌های صفحه‌ساز برای تولید این ساختار کمک بگیری.

۲. استایل‌دهی CSS: زنده کردن اسکلت

حالا وقتشه که به اسکلتونمون کمی رنگ و لعاب بدیم. از CSS برای تعیین ابعاد، رنگ پس‌زمینه و مهم‌تر از همه، انیمیشن لودینگ استفاده می‌کنیم. انیمیشن باعث میشه اسکلتون زنده به نظر برسه و کاربر متوجه بشه که داره اتفاقی میفته.

🔗 کپی کد


.content-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.card {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    width: 300px;
    padding: 20px;
    text-align: center;
    border: 1px solid #eee;
}

.card-image {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 6px;
    margin-bottom: 15px;
    background-color: #e0e0e0; /* Fallback for image loading */
}

.card-title {
    font-size: 1.6em;
    color: #333;
    margin-bottom: 10px;
}

.card-description {
    font-size: 0.95em;
    color: #666;
    line-height: 1.6;
    margin-bottom: 20px;
}

.card-button {
    background-color: #3498db;
    color: white;
    padding: 10px 20px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 1em;
    transition: background-color 0.3s ease;
}

.card-button:hover {
    background-color: #2980b9;
}


/* Skeleton Screen Styles */
.skeleton-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.card-skeleton {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    width: 300px;
    padding: 20px;
    border: 1px solid #eee;
    animation: pulse 1.5s infinite ease-in-out; /* Add animation */
    -webkit-animation: pulse 1.5s infinite ease-in-out; /* For Safari/Chrome */
}

.skeleton-image,
.skeleton-title,
.skeleton-description,
.skeleton-button {
    background-color: #e0e0e0; /* Gray base color */
    border-radius: 4px;
    margin-bottom: 10px;
}

.skeleton-image {
    width: 100%;
    height: 180px;
}

.skeleton-title {
    width: 80%;
    height: 25px;
}

.skeleton-description {
    width: 95%;
    height: 18px;
}
.skeleton-description:nth-child(4) { /* A second line for description */
    width: 70%;
}
.skeleton-button {
    width: 100px;
    height: 40px;
    margin-top: 15px;
    margin-bottom: 0; /* Override default margin */
}

/* Pulse Animation */
@keyframes pulse {
    0% {
        background-color: #e0e0e0;
    }
    50% {
        background-color: #f0f0f0;
    }
    100% {
        background-color: #e0e0e0;
    }
}

@-webkit-keyframes pulse { /* For Safari/Chrome */
    0% {
        background-color: #e0e0e0;
    }
    50% {
        background-color: #f0f0f0;
    }
    100% {
        background-color: #e0e0e0;
    }
}

/* Media Queries for Responsiveness */
@media (max-width: 768px) {
    .card, .card-skeleton {
        width: 90%; /* Make cards wider on smaller screens */
    }
}

تو این کد، اول برای کارت‌های اصلی یه سری استایل پایه گذاشتیم. بعدش رفتیم سراغ کلاس‌های `skeleton-` و براشون رنگ خاکستری (#e0e0e0) رو به عنوان پس‌زمینه در نظر گرفتیم. مهم‌ترین بخش، انیمیشن `pulse` هست که باعث میشه رنگ پس‌زمینه بین دو طیف خاکستری کم‌رنگ و پررنگ‌تر نوسان کنه و حس لود شدن رو بده. این انیمیشن رو به کلاس `card-skeleton` اضافه کردیم که به کل کارت اعمال بشه. در نهایت هم یه کد واکنش‌گرایی ساده (Media Query) گذاشتیم تا تو موبایل و تبلت هم ظاهرش خوب باشه.

۳. منطق JavaScript: سوئیچ بین اسکلت و محتوا

حالا که اسکلت و استایل‌ها آماده‌ان، باید با JavaScript مدیریت کنیم که چه زمانی اسکلتون اسکرین نمایش داده بشه و چه زمانی محتوای اصلی. ایده اینه که اسکلتون رو تا زمانی که داده‌ها از سرور لود شدن نشون بدیم و بعدش اون رو مخفی کنیم و محتوای اصلی رو نمایش بدیم.

🔗 کپی کد


// شبیه‌سازی لود شدن داده از سرور
function fetchData() {
    return new Promise(resolve => {
        setTimeout(() => {
            // فرض می‌کنیم داده‌ها اینجا لود شدن
            const data = [
                { id: 1, title: "تیتر محصول یک", description: "توضیحات جذاب محصول شماره یک.", imageUrl: "https://via.placeholder.com/300x180/FF5733/FFFFFF?text=Product+1" },
                { id: 2, title: "کالای دیجیتال دو", description: "ویژگی‌های بی‌نظیر کالای دوم و کاربرد‌های آن.", imageUrl: "https://via.placeholder.com/300x180/33FF57/FFFFFF?text=Product+2" }
            ];
            resolve(data);
        }, 3000); // شبیه‌سازی 3 ثانیه تاخیر در لودینگ
    });
}

function renderContent(data) {
    const actualContentDiv = document.getElementById('actual-content');
    actualContentDiv.innerHTML = ''; // پاک کردن محتوای قبلی در صورت وجود

    data.forEach(item => {
        const cardDiv = document.createElement('div');
        cardDiv.className = 'card';
        cardDiv.innerHTML = `
            <img src="${item.imageUrl}" alt="${item.title}" class="card-image">
            <h2 class="card-title">${item.title}</h2>
            <p class="card-description">${item.description}</p>
            <button class="card-button">مشاهده محصول</button>
        `;
        actualContentDiv.appendChild(cardDiv);
    });

    document.getElementById('skeleton-content').style.display = 'none'; // مخفی کردن اسکلتون
    actualContentDiv.style.display = 'flex'; // نمایش محتوای واقعی
}

// اجرای فرایند لودینگ
document.addEventListener('DOMContentLoaded', () => {
    fetchData().then(data => {
        renderContent(data);
    });
});

تو این کد جاوااسکریپت:

  • fetchData() یه تابع شبیه‌سازی شده برای دریافت داده از سروره که با یه `setTimeout`، سه ثانیه تاخیر مصنوعی ایجاد می‌کنه. تو پروژه واقعی خودت، این تابع همون فراخوانی API یا لودینگ دیتای واقعی از دیتابیس یا سرویس‌های دیگه‌ت هست.
  • renderContent(data) تابعیه که وقتی داده‌ها آماده شدن، اونا رو تو قالب HTML می‌ریزه و بعدش اسکلتون رو مخفی می‌کنه و محتوای اصلی رو نمایش میده.
  • در نهایت، با `DOMContentLoaded` مطمئن میشیم که این اسکریپت بعد از اینکه DOM کاملاً لود شد اجرا میشه تا مشکلی پیش نیاد.

بهترین روش‌ها و نکته‌های حرفه‌ای

ساختن یه اسکلتون اسکرین خوب فقط به کد زدن خلاصه نمیشه. یه سری نکته و ترفند هست که اگه رعایتشون کنی، نتیجه کارت خیلی حرفه‌ای‌تر میشه:

  • شبیه به محتوای نهایی باشه: سعی کن اسکلتون اسکرین تا حد امکان شبیه به محتوای نهایی باشه، هم از نظر چیدمان و هم از نظر ابعاد نسبی عناصر. این به کاربر کمک می‌کنه محتوا رو بهتر پیش‌بینی کنه.
  • ساده و مینیمال: زیاده‌روی تو طراحی اسکلتون نکن. هدف اصلی اطلاع‌رسانیه، نه اینکه خودش یه طراحی پیچیده باشه. رنگ‌های خنثی و اشکال ساده بهترین انتخاب هستن.
  • زمان‌بندی مناسب: اگه زمان لودینگ خیلی کوتاهه (مثلاً کمتر از ۳۰۰ میلی‌ثانیه)، نیازی به اسکلتون اسکرین نیست. نمایش و پنهان کردن سریع اون می‌تونه باعث فلیکر (flicker) بشه و تجربه کاربری رو بدتر کنه.
  • بهینه‌سازی برای موبایل: مطمئن شو که اسکلتون اسکرین تو موبایل هم خوب نمایش داده میشه. از واحدهای نسبی مثل `%` یا `vw`/`vh` برای ابعاد استفاده کن تا واکنش‌گرایی عالی داشته باشه.
  • دسترسی‌پذیری (Accessibility): برای کاربران با محدودیت‌های بینایی، اسکلتون اسکرین ممکنه چالش ایجاد کنه. از ویژگی‌های ARIA مثل `aria-busy=”true”` و `aria-label=”Loading content”` استفاده کن تا Screen Readerها هم بتونن وضعیت لودینگ رو به کاربر اطلاع بدن.
  • ترکیب با اسپینر: تو بعضی موارد خاص، اگه لودینگ بخش‌های خاصی از صفحه زمان‌بره، می‌تونی اسکلتون رو با یه اسپینر کوچک ترکیب کنی تا کاربر دقیقا بدونه کدوم بخش هنوز در حال بارگذاریه.

مقایسه: اسکلتون اسکرین در برابر سایر روش‌های لودینگ

برای اینکه بهتر متوجه بشی اسکلتون اسکرین چه برتری‌هایی داره، بیا یه مقایسه سریع با روش‌های دیگه لودینگ بندازیم:

روش لودینگ ویژگی‌ها و مزایا
اسکلتون اسکرین
  • بهبود محسوس عملکرد
  • کاهش استرس کاربر
  • پیش‌نمایش چیدمان محتوا
  • ظاهر مدرن و حرفه‌ای
لودینگ اسپینر (Spinners)
  • ساده و کم‌حجم
  • مشخص می‌کند عملیات در حال انجام است
  • اطلاعی از محتوای آینده نمی‌دهد
  • گاهی باعث خستگی کاربر می‌شود
صفحه خالی (Blank Page)
  • ساده‌ترین روش
  • بدترین تجربه کاربری
  • افزایش شدید نرخ پرش
  • کاربر را سردرگم می‌کند
پیام “در حال بارگذاری…”
  • اطلاع‌رسانی واضح
  • نسبتاً ساده
  • نیاز به محتوای متنی و ترجمه
  • میتواند خسته‌کننده باشد

عیب‌یابی سریع و راه‌حل‌ها (Troubleshooting)

تو مسیر پیاده‌سازی اسکلتون اسکرین ممکنه به یه سری مشکل بربخوری. نگران نباش، این طبیعیه! بیا چندتا از مشکلات رایج و راه‌حل‌هاشون رو با هم مرور کنیم:

⚠️ مشکلات رایج و راه‌حل‌ها

  • مشکل: اسکلتون ناپدید میشه و محتوای واقعی فلیکر (Flicker) می‌کنه.

    راه‌حل: این مشکل معمولاً وقتی پیش میاد که لودینگ خیلی سریع انجام میشه. برای لودینگ‌های کمتر از ۳۰۰ میلی‌ثانیه، بهتره اصلاً اسکلتون اسکرین رو نشون ندی و مستقیم محتوا رو نمایش بدی. می‌تونی از یه `minimum-display-time` با جاوااسکریپت استفاده کنی تا مطمئن بشی اسکلتون حداقل برای یه مدت مشخص (مثلاً ۵۰۰ میلی‌ثانیه) نمایش داده میشه.

  • مشکل: انیمیشن اسکلتون روان نیست یا لگ داره.

    راه‌حل: مطمئن شو که از ویژگی‌های CSS که به GPU کمک می‌کنن (مثل `transform: translateZ(0);` یا `will-change: background-color, transform;`) استفاده می‌کنی. انیمیشن‌هایی مثل `background-color` ممکنه روی CPU پردازش بشن و باعث لگ بشن. سعی کن از `keyframes` برای `opacity` یا `transform` استفاده کنی که بهینه تر هستن.

  • مشکل: اسکلتون اسکرین روی دستگاه‌های مختلف، ظاهر متفاوتی داره یا واکنش‌گرا نیست.

    راه‌حل: همیشه از واحدهای نسبی مثل `width: 100%`, `height: auto`, `padding: 2%` و `em`/`rem` برای اندازه‌ها استفاده کن. حتماً از Media Queries برای تنظیمات خاص موبایل و تبلت استفاده کن. می‌تونی از فریمورک‌های CSS مثل Bootstrap یا Tailwind CSS هم کمک بگیری که خودشون اصول واکنش‌گرایی رو دارن.

  • مشکل: محتوای واقعی بارگذاری شده، اما اسکلتون پنهان نمیشه.

    راه‌حل: این مشکل معمولاً به خاطر خطای جاوااسکریپت یا عدم دسترسی به المان‌هاست. مطمئن شو که `id`های `actual-content` و `skeleton-content` رو درست تو HTML و JavaScriptت گذاشتی. همچنین، بررسی کن که تابع `renderContent` بعد از اتمام لودینگ داده‌ها، حتماً فراخوانی میشه و کد `document.getElementById(‘skeleton-content’).style.display = ‘none’;` اجرا میشه. Console مرورگرت رو چک کن که اروری نباشه.

  • مشکل: اسکلتون اسکرین برای Screen Readerها قابل تشخیص نیست.

    راه‌حل: برای بهبود دسترسی‌پذیری، می‌تونی ویژگی `aria-hidden=”true”` رو به اسکلتون اسکرین اضافه کنی تا برای Screen Readerها پنهان بشه، و یه پیام `aria-label=”Loading content”` روی یه المان مخفی نگه دار که وضعیت رو به کاربر اطلاع بده. مثلاً: `

    Loading content…

    `

نتیجه‌گیری

ساختن اسکلتون اسکرین یه راهکار قدرتمند و نسبتاً ساده است که می‌تونه تجربه کاربری سایت یا اپلیکیشن شما رو به طور چشمگیری بهبود بده. با پیاده‌سازی این تکنیک، نه تنها زمان لودینگ رو برای کاربر “کوتاه” می‌کنید، بلکه حس حرفه‌ای بودن و دقت به جزئیات رو هم بهش منتقل می‌کنید. یادت باشه که مهمترین هدف، ایجاد یه حس خوب برای کاربره و اسکلتون اسکرین دقیقا همین کار رو به ظرافت انجام میده. امیدوارم این راهنمای جامع بهت کمک کرده باشه تا لودینگ‌های پروژه‌هات رو جذاب‌تر و کارآمدتر کنی. اگه سوالی داشتی یا نیاز به راهنمایی بیشتر تو حوزه‌ی پایتون، CSS، جاوااسکریپت، HTML یا وردپرس داشتی، حتماً به بخش کدهای آماده و اسنیپت‌های ما سر بزن یا باهامون تماس بگیر.

❓ سوالات متداول (FAQ Schema)

اسکلتون اسکرین چیه؟

اسکلتون اسکرین یه الگوی طراحی UI هست که به جای نمایش صفحه خالی یا اسپینر لودینگ، یه نسخه ساده و کم‌رنگ از ساختار محتوای نهایی رو نشون میده تا کاربر حس کنه صفحه در حال بارگذاریه و منتظر نمونه.

چرا باید از اسکلتون اسکرین استفاده کنیم؟

استفاده از اسکلتون اسکرین تجربه کاربری (UX) رو به شدت بهبود میده، چون حس “عمل کرد محسوس” (Perceived Performance) رو تو کاربر ایجاد می‌کنه. این کار باعث کاهش نرخ پرش، افزایش زمان ماندگاری کاربر و حرفه‌ای‌تر دیده شدن رابط کاربری میشه.

اسکلتون اسکرین روی سئو تاثیر داره؟

به طور مستقیم نه، اما به طور غیرمستقیم بله. با بهبود تجربه کاربری و کاهش نرخ پرش و افزایش زمان ماندگاری کاربر، سیگنال‌های مثبت به گوگل ارسال میشه که می‌تونه به رتبه بهتر سایت کمک کنه. سرعت لود سایت و Core Web Vitals هم از فاکتورهای مهم سئو هستن که اسکلتون اسکرین در بهبودشون نقش داره.

چطور اسکلتون اسکرین رو واکنش‌گرا (Responsive) بسازیم؟

برای ساخت یه اسکلتون واکنش‌گرا، باید از واحدهای نسبی مثل درصد (%em، rem، vw/vh برای ابعاد استفاده کنی. همچنین، استفاده از Media Queries تو CSS ضروریه تا بتونی استایل‌های خاصی رو برای اندازه‌های مختلف صفحه (موبایل، تبلت، دسکتاپ) اعمال کنی.

آیا همیشه باید از اسکلتون اسکرین استفاده کنیم؟

خیر. اگه زمان لودینگ محتوا خیلی کوتاهه (کمتر از ۳۰۰ میلی‌ثانیه)، نمایش اسکلتون اسکرین ممکنه باعث فلیکر و تجربه بدتر بشه. بهتره فقط برای لودینگ‌های متوسط تا طولانی از این تکنیک استفاده کنی.

Table of Contents

آخرین نوشته‌ها