آنچه در این مقاله میخوانید
آموزش توسعهی Loading Spinner با استفاده از CSS
۲۴ فروردین ۱۴۰۰
در این مقاله تصمیم داریم تا با استفاده از CSS یک Loading Spinner ایجاد کنیم و بدون فوت وقت بهسراغ قدم اول این آموزش میرویم.
آنچه در این مقاله میخوانید:
- آموزش گامبهگام ساخت Loading Spinner با CSS
- مزایای این روش در طراحی وب
- جمع بندی

آموزش گامبهگام ساخت Loading Spinner با CSS
Loading Spinner یا نماد بارگذاری یکی از رایجترین عناصر رابط کاربری برای نمایش وضعیت لودینگ دادهها، فرمها یا صفحات در وبسایتها است. در این آموزش جامع، یاد میگیریم چگونه تنها با استفاده از HTML و CSS، بدون نیاز به جاوااسکریپت یا کتابخانههای اضافی، یک لودینگ اسپینر مدرن و واکنشگرا طراحی کنیم.
گام اول: ساختار HTML اولیهی Spinner
در این مرحله میخواهیم ساختار Spinner مورد نظرمان را پیادهسازی کنیم بنابراین در فایل index.html
خود یک div
قرار دهید و به آن یک class با نام spinner
بدهید:
<div class = "spinner"></div>
پس از این کار بایستی class فوق را در فایل index.css
تعریف کنیم:
body {
bodybackground: #050115;
}
.spinner {
width: 10em;
height: 10em;
border-top: 1em solid #d5fff7;
border-right: 1em solid transparent;
border-radius: 50%;
}
گام دوم: افزودن عنصر داخلی برای ایجاد افکت هد (Head)
پس از ایجاد ساختار کلی Spinner یک div
دیگر به درون آن اضافه میکنیم و یک class با نام head
به آن اختصاص میدهیم:
<div class="spinner">
<div class="head"></div>
</div>
در مرحلهی بعد بایستی head
را در کدهای CSS خود تعریف کرده و موقعیت آن را تعریف کنیم:
.head {
width: 1em;
height: 1em;
background-color: #d5fff7;
border-radius: 50%;
margin-left: 8.5em;
margin-top: 0.5em;
}
گام سوم: مرکزچین کردن Spinner در صفحه
در این بخش تصمیم داریم تا Spinner خود را در وسط صفحه قرار دهیم تا توجه کاربران را بهخود جلب کند بنابراین در کدهای CSS مقدار margin: auto;
را به spinner
اضافه میکنیم:
.spinner {
width: 10em;
height: 10em;
border-top: 1em solid #d5fff7;
border-right: 1em solid transparent;
border-radius: 50%;
margin: auto;
}
پس از این کار متوجه میشوید که Spinner فقط بهصورت افقی در وسط صفحه قرار گرفته زیرا ارتفاع body
بهاندازهی کل صفحه نیست. راه حل بهصورت زیر است:
body {
background: #050115;
display: flex;
height: 100vh;
width: 100vw;
overflow: hidden;
}
گام چهارم: افزودن انیمیشن چرخشی با استفاده از CSS
برای چرخش Spinner باید از animation
استفاده کنیم که تعریف آن بهشکل زیر است:
.spinner {
width: 10em;
height: 10em;
border-top: 1em solid #d5fff7;
border-right: 1em solid transparent;
border-radius: 50%;
margin: auto;
animation: spinner 0.6s linear infinite;
}
در animation برای animation-name
از spinner
استفاده کردیم که شما میتوانید از هر نام دلخواه دیگری استفاده کنید. مقدار 0.6s
مدت زمانی است که animation ما از ۰ درصد به ۱۰۰ درصد میرسد. linear
به ما کمک میکند تا اجرای animation روان باشد و در نهایت مقدار infinite
وجود دارد که با توجه به معنای میتوانیم متوجه شویم که animation ما به تعداد بینهایت بار تکرار میشود.
بیایید animation مورد نظرمان که در مرحلهی قبل نام آن را spinner
گذشته بودیم، تعریف کنیم:
@keyframes spinner {
100% {
transform: rotate(360deg)
}
}
گام پنجم: تغییر اندازهی Spinner با استفاده از font-size
در این بخش میخواهیم به شما بگوییم که چگونه میتوانید اندازهی Spinner را تغییر دهید. این کار بسیار ساده است و فقط نیاز داریم تا font-size
را بهعنوان یک inline-style
به Spinner خود بدهیم:
<div class="spinner" style="font-size: 10px">
<div class="head"></div>
</div>
مقدار پیشفرض 16px
یا 1rem
است بنابراین برای مشاهدهی تغییرها بایستی مقدار متفاوتی به font-size
بدهید.
مزایای این روش در طراحی وب
- کاملاً سبک و بدون نیاز به کتابخانهی اضافی
- مناسب برای پروژههای SPA و SSR
- قابل شخصیسازی از نظر رنگ، اندازه و سرعت انیمیشن
- بهینه برای سئو و تجربه کاربری بهتر در صفحات در حال بارگذاری
جمع بندی
در این آموزش یاد گرفتیم که چگونه با استفاده از HTML و CSS یک Loading Spinner ساده و زیبا ایجاد کنیم. با تعریف ساختار HTML، طراحی ظاهر با CSS، افزودن انیمیشن چرخشی، قرار دادن Spinner در مرکز صفحه و امکان تغییر اندازهی آن، موفق شدیم یک عنصر کاربردی و سبک برای نمایش وضعیت بارگذاری بسازیم.
این تکنیک، راهی سریع و مؤثر برای بهبود تجربهی کاربری در هنگام لود محتوا است و بدون نیاز به جاوااسکریپت یا کتابخانههای سنگین، بهراحتی در انواع پروژهها قابل استفاده خواهد بود.
منبع: https://designingcoder.hashnode.dev/creating-a-simple-head-tail-loading-spinner-using-vanilla-css