تصاویر

تصاویر تزئینی، مانند شیب پس‌زمینه روی دکمه‌ها یا تصاویر پس‌زمینه در بخش‌هایی از محتوا یا کل صفحه، نمایشی هستند و باید با CSS اعمال شوند. هنگامی که یک تصویر زمینه را به یک سند اضافه می کند، محتوا است و باید با HTML جاسازی شود.

روش اصلی برای گنجاندن تصاویر، تگ <img> با ویژگی src است که به منبع تصویر ارجاع می دهد و ویژگی alt تصویر را توصیف می کند.

<img src="images/eve.png" alt="Eve">

هر دو ویژگی srcset در <img> و عنصر <picture> راهی را برای گنجاندن چندین منبع تصویر با پرس و جوهای رسانه مرتبط، هر کدام با یک منبع تصویر بازگشتی فراهم می‌کنند، که امکان ارائه مناسب‌ترین فایل تصویری را بر اساس وضوح دستگاه، قابلیت‌های مرورگر، فراهم می‌کند. و اندازه ویوپورت ویژگی srcset امکان ارائه چندین نسخه تصویر را بر اساس وضوح و به همراه ویژگی sizes ، اندازه درگاه دید مرورگر فراهم می‌کند.

<img src="images/eve.png" alt="Eve"
  srcset="images/eve.png 400w, images/eve-xl.jpg 800w"
  sizes="(max-width: 800px) 400px, 800px" />

این را می توان با عنصر <picture> به همراه <source> فرزندان نیز انجام داد که یک <img> به عنوان منبع پیش فرض می گیرد.

<picture>
  <source src="images/eve.png" media="(max-width: 800px)" />
  <source src="images/eve-xl.jpg" />
  <img src="images/eve.png" alt="Eve" />
</picture>

علاوه بر این روش‌های داخلی پاسخ‌گوی تصویر HTML، HTML همچنین عملکرد رندر تصویر را از طریق ویژگی‌های مختلف بهبود می‌بخشد. تگ <img> و در نتیجه دکمه‌های ارسال گرافیکی <input type="image"> می‌تواند شامل ویژگی‌های height و width برای تنظیم نسبت تصویر برای کاهش تغییر طرح‌بندی محتوا باشد. ویژگی lazy بارگذاری تنبل را فعال می کند.

HTML همچنین از گنجاندن تصاویر SVG با استفاده از <svg> به طور مستقیم پشتیبانی می کند، اگرچه تصاویر SVG با پسوند .svg (یا به عنوان داده-uri ) را می توان با استفاده از عنصر <img> جاسازی کرد.

حداقل، هر تصویر پیش زمینه باید دارای ویژگی های src و alt باشد.

فایل src مسیر و نام فایل تصویر تعبیه شده است. ویژگی src برای ارائه URL تصویر استفاده می شود. سپس مرورگر دارایی را واکشی می کند و آن را به صفحه نمایش می دهد. این ویژگی توسط <img> مورد نیاز است. بدون آن، چیزی برای ارائه وجود ندارد.

ویژگی alt متن جایگزینی را برای تصویر ارائه می‌کند و برای کسانی که نمی‌توانند صفحه را ببینند (به موتورهای جستجو و فن‌آوری‌های کمکی فکر کنید و حتی الکسا، سیری و دستیار گوگل) توضیحی از تصویر ارائه می‌دهد و ممکن است در صورت مشاهده توسط مرورگر نمایش داده شود. تصویر بارگذاری نمی شود علاوه بر کاربرانی با شبکه های کند یا پهنای باند محدود، متن alt در ایمیل های HTML فوق العاده مفید است، زیرا بسیاری از کاربران تصاویر را در برنامه های ایمیل خود مسدود می کنند.

<img src="path/filename" alt="descriptive text" />

اگر تصویر از نوع فایل SVG است، role="img" را نیز وارد کنید، که به دلیل اشکالات VoiceOver ضروری است.

<img src="switch.svg" alt="light switch" role="img" />

نوشتن توضیحات تصویر alt موثر

هدف ویژگی‌های Alt کوتاه و مختصر است و تمام اطلاعات مرتبطی را که تصویر منتقل می‌کند، ارائه می‌کند، در حالی که اطلاعاتی را که برای محتوای دیگر در سند اضافی هستند یا در موارد دیگر مفید نیستند حذف می‌کنند. در نوشتن متن، لحن باید منعکس کننده لحن سایت باشد.

برای نوشتن متن جایگزین موثر، تصور کنید که کل صفحه را برای شخصی می خوانید که نمی تواند آن را ببیند. با استفاده از عنصر معنایی <img> ، کاربران و ربات های صفحه خوان مطلع می شوند که عنصر یک تصویر است. اضافه کردن "این یک تصویر/نمایش تصویر/عکس از" در alt است اضافی است. کاربر نیازی به دانستن وجود تصویر ندارد، اما باید بداند که تصویر چه اطلاعاتی را منتقل می کند.

به طور معمول، شما نمی گویید: "این یک تصویر دانه دانه از سگی است که کلاه قرمزی بر سر دارد." در عوض، آنچه را که تصویر بیان می‌کند در رابطه با زمینه بقیه سند منتقل می‌کنید. و آنچه شما منتقل می کنید بسته به زمینه و محتوای متن اطراف تغییر می کند.

به عنوان مثال، عکس یک سگ بسته به زمینه، به روش های مختلفی توصیف می شود. اگر Fluffy یک آواتار در کنار بررسی غذای سگ Yuckymeat باشد، alt="Fluffy" کافی است.

اگر عکس بخشی از صفحه فرزندخواندگی فلافی در یک وب سایت پناهگاه حیوانات باشد، مخاطب هدف والدین سگ آینده است. متن باید اطلاعاتی را که در تصویر منتقل می‌شود و مربوط به گیرنده است و در متن اطراف تکراری نیست، توصیف کند. توضیحات طولانی تر، مانند alt="Fluffy, a tri-color terrier with very short hair, with a tennis ball in her mouth" مناسب است. متن صفحه فرزندخواندگی به طور کلی شامل گونه، نژاد، سن و جنسیت حیوان خانگی قابل پذیرش است، بنابراین نیازی به تکرار در متن جایگزین نیست. اما بیوگرافی نوشته شده سگ احتمالاً شامل طول مو، رنگ یا ترجیحات اسباب بازی نیست. توجه داشته باشید که ما تصویر را توضیح ندادیم: صاحب سگ بالقوه نیازی به دانستن اینکه آیا سگ در داخل خانه است یا خارج از خانه است یا اینکه قلاده قرمز و افسار آبی دارد.

هنگام استفاده از تصاویر برای شمایل نگاری، از آنجایی که ویژگی alt نام قابل دسترسی را ارائه می دهد، معنای نماد را منتقل کنید، نه توضیحی از تصویر. برای مثال، ویژگی alt نماد ذره بین search است. نمادی که به نظر می رسد یک خانه دارای home به عنوان متن جایگزین است. شرح نماد دیسک فلاپی 5 اینچی save است. اگر از دو نماد Fluffy برای نشان دادن بهترین شیوه‌ها و ضد الگوها استفاده می‌شود، سگ خندان در کلاه سبز می‌تواند مجموعه alt="good" داشته باشد، در حالی که سگ خرخر با کلاه قرمز ممکن است alt="bad" بخواند. همانطور که گفته شد، فقط از نمادهای استاندارد استفاده کنید، و اگر از نمادهای غیر استاندارد مانند Fluffy خوب و بد استفاده می کنید، یک افسانه اضافه کنید و مطمئن شوید که نمادها تنها راه های رمزگشایی معنای عناصر رابط کاربری شما نیستند.

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

اطلاعاتی را که کاربر قبلاً از زمینه می داند و در غیر این صورت در محتوا از آنها مطلع شده است حذف کنید. به عنوان مثال، اگر در یک صفحه آموزشی در مورد تغییر تنظیمات مرورگر هستید و صفحه مربوط به کلیک کردن روی نمادها در مرورگر کروم است، URL صفحه در تصویربرداری صفحه مهم نیست. alt به موضوع مورد نظر محدود کنید: نحوه تغییر تنظیمات. alt ممکن است "نماد تنظیمات در نوار پیمایش زیر فیلد جستجو است." «اسکرین‌شات» یا «کارگاه یادگیری ماشینی» را وارد نکنید، زیرا کاربر نیازی ندارد بداند که این یک اسکرین‌شات است و نیازی هم ندارد که بداند نویسنده فنی هنگام نوشتن دستورالعمل‌ها در کجا گشت می‌زد. توصیف تصویر بر اساس زمینه ای است که چرا تصویر در وهله اول گنجانده شده است.

اگر تصویربرداری از صفحه نشان می‌دهد که چگونه می‌توان شماره نسخه مرورگر را با رفتن به chrome://version/ پیدا کرد، URL را در محتوای صفحه به‌عنوان دستورالعمل اضافه کنید، و یک رشته خالی به عنوان ویژگی alt ارائه دهید، زیرا تصویر هیچ اطلاعاتی را ارائه نمی‌کند. در متن اطراف نیست.

اگر تصویر هیچ اطلاعات اضافی ارائه نمی دهد یا صرفاً تزئینی است، مشخصه باید همچنان وجود داشته باشد، درست به عنوان یک رشته خالی.

<img src="svg/magazine.svg" alt="" role="none" />

MachineLearningWorkshop.com دارای هفت تصویر پیش‌زمینه است، بنابراین هفت تصویر با ویژگی‌های alt: یک سوئیچ چراغ تخم مرغ عید پاک، یک نماد دستی، دو عکس بیوگرافی از هال و ایو، و سه آواتار یک مخلوط‌کن، یک جاروبرقی و یک توستر. تصویر پیش زمینه ای که شبیه یک مجله است تنها تصویری است که صرفاً تزئینی است. صفحه همچنین دارای دو تصویر پس زمینه است. اینها همچنین تزئینی هستند و همانطور که با CSS اضافه می شوند، غیرقابل دسترسی هستند.

این مجله، صرفاً تزئینی است، دارای ویژگی alt خالی است و role none به عنوان تصویر یک SVG صرفاً نمایشی است. اگر معنی دار باشد، تصاویر SVG باید شامل role="img" باشند.

<img src="svg/magazine.svg" alt="" role="none" />

سه بررسی در پایین صفحه وجود دارد که هر کدام دارای تصویری از پوستر هستند. معمولاً متن alt نام شخص تصویر شده است.

<img src="images/blender.svg" alt="Blendan Smooth" role="img" />

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

<img src="images/blender.svg" alt="blender" role="img" />

عکس های مربیان فقط آواتار نیستند: آنها تصاویر بیوگرافی هستند و بنابراین توضیحات دقیق تری دریافت می کنند.

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

<img src="svg/hal.svg" role="img"
  alt="Hal 9000; a camera lens containing a red dot that sometimes changes to yellow." />

از آنجایی که این یک سایت جوک است، به جای آن اطلاعاتی را که در زمینه جوک مرتبط است ارائه دهید:

<img src="svg/hal.svg" role="img"
  alt="Hal 9000, the sentient AI computer from 2001: a Space Odyssey depicted as a camera lens with a red dot that changes to yellow when hovered." />

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

هنگام نوشتن متن توصیفی، در نظر بگیرید که تصویر چه اطلاعاتی مهم و مرتبط با کاربر را منتقل می کند و شامل آن می شود. به یاد داشته باشید، محتوای ویژگی alt برای یک تصویر بر اساس زمینه متفاوت است. تمام اطلاعات منتقل شده در تصویری که یک کاربر بینا می تواند به آن دسترسی داشته باشد و مرتبط با زمینه است، چیزی است که باید منتقل شود. هیچ چیز بیشتر آن را کوتاه، دقیق و مفید نگه دارید.

ویژگی های src و alt حداقل الزامات برای تصاویر جاسازی شده هستند. چند ویژگی دیگر وجود دارد که باید در مورد آنها بحث کنیم.

تصاویر واکنش گرا

تعداد بی شماری از اندازه های دید وجود دارد. وضوح صفحه نمایش نیز متفاوت است. شما نمی خواهید پهنای باند کاربر تلفن همراه را با ارائه تصویری به اندازه کافی برای نمایشگر صفحه نمایش بزرگ به آنها هدر دهید، اما ممکن است بخواهید تصاویر با وضوح بالاتر را برای دستگاه های کوچکی که چهار برابر وضوح صفحه نمایش معمولی دارند ارائه دهید. چند راه برای ارائه تصاویر مختلف بر اساس اندازه دید و وضوح صفحه وجود دارد.

ویژگی <img> srcset

ویژگی srcset پیشنهاد چندین فایل تصویری را امکان پذیر می کند، با مرورگر انتخاب تصویری که بر اساس درخواست های رسانه ای متعدد از جمله اندازه درگاه نمایش و وضوح صفحه نمایش درخواست کند.

برای هر عنصر <img> می‌تواند یک ویژگی srcset وجود داشته باشد، اما آن srcset می‌تواند به چندین تصویر پیوند دهد. ویژگی srcset لیستی از مقادیر جدا شده با کاما را می پذیرد، که هر کدام حاوی URL دارایی است و پس از آن یک فاصله به دنبال توصیفگرهایی برای آن گزینه تصویر وجود دارد. اگر از یک توصیف‌کننده عرض استفاده می‌شود، باید ویژگی sizes با یک پرسش رسانه یا اندازه منبع برای هر گزینه srcset به غیر از گزینه آخر اضافه کنید. بخش‌های Learn که تصاویر واکنش‌گرا را srcset سینتکس‌های srcset و توصیفی پوشش می‌دهد ارزش خواندن دارد.

در صورت وجود مطابقت، تصویر srcset بر تصویر src اولویت خواهد داشت.

<picture> و <source>

روش دیگری برای ارائه منابع متعدد و اجازه دادن به مرورگر برای ارائه مناسب ترین دارایی، استفاده از عنصر <picture> است. عنصر <picture> یک عنصر محفظه برای چندین گزینه تصویر است که در تعداد نامحدودی از عناصر <source> و یک عنصر <img> مورد نیاز فهرست شده است.

ویژگی‌های <source> شامل srcset ، sizes ، media ، width و height است. ویژگی srcset برای img ، source و link مشترک است، اما عموماً کمی متفاوت در منبع پیاده‌سازی می‌شود، زیرا پرس‌وجوهای رسانه را می‌توان در ویژگی رسانه <srcset> فهرست کرد. <source> همچنین از فرمت های تصویر تعریف شده در ویژگی type پشتیبانی می کند.

مرورگر هر عنصر <source> فرزند را در نظر می گیرد و بهترین تطابق را از بین آنها انتخاب می کند. اگر هیچ منطبقی یافت نشد، URL ویژگی src عنصر <img> انتخاب می شود. نام قابل دسترسی از ویژگی alt در تودرتو <img> می آید. بخش‌های Learn که عنصر <picture> و نحو تجویزی را پوشش می‌دهند نیز ارزش خواندن دارند.

ویژگی های عملکرد اضافی

بارگذاری تنبل

ویژگی loading به مرورگر دارای JS می گوید که چگونه تصویر را بارگذاری کند. مقدار پیش‌فرض eager به این معنی است که تصویر بلافاصله با تجزیه HTML بارگیری می‌شود، حتی اگر تصویر خارج از نمای قابل مشاهده باشد. با تنظیم loading="lazy" بارگذاری تصویر به تعویق می افتد تا زمانی که احتمال می رود وارد درگاه نمایش شود. "احتمالا" توسط مرورگر بر اساس فاصله تصویر از درگاه دید تعریف می شود. این با پیمایش کاربر به روز می شود. بارگذاری تنبل به صرفه جویی در پهنای باند و CPU کمک می کند و عملکرد را برای اکثر کاربران بهبود می بخشد. اگر جاوا اسکریپت غیرفعال باشد، به دلایل امنیتی، همه تصاویر به‌طور پیش‌فرض روی eager خواهند بود.

<img src="switch.svg" alt="light switch" loading="lazy" />

نسبت ابعاد

مرورگرها پس از دریافت HTML شروع به رندر کردن می‌کنند و در صورت مواجهه با آن، درخواست‌هایی برای دارایی‌ها ارائه می‌کنند. این بدان معناست که مرورگر از قبل HTML را هنگامی که با تگ <img> روبرو می شود و درخواست می کند، ارائه می دهد. و بارگیری تصاویر ممکن است کمی طول بکشد. به‌طور پیش‌فرض، مرورگرها فضایی به جز اندازه مورد نیاز برای ارائه متن alt برای تصاویر رزرو نمی‌کنند.

عنصر <img> همیشه از ویژگی‌های height و width بدون واحد پشتیبانی می‌کند. این ویژگی ها به نفع CSS از کار افتادند. CSS ممکن است ابعاد تصویر را تعریف کند، اغلب یک بعد واحد مانند max-width: 100%; برای اطمینان از حفظ نسبت تصویر. از آنجایی که CSS معمولاً در <head> گنجانده می شود، قبل از اینکه با <img> مواجه شود تجزیه می شود. اما بدون ذکر صریح height یا نسبت ابعاد، فضای رزرو شده ارتفاع (یا عرض) متن alt است. با توجه به اینکه اکثر توسعه دهندگان فقط عرض را اعلام می کنند، دریافت و ارائه تصاویر منجر به تغییر چیدمان تجمعی می شود که به حیاتی وب آسیب می رساند. برای حل این مشکل، مرورگرها از نسبت تصویر پشتیبانی می کنند. شامل ویژگی‌های height و width در <img> به‌عنوان نکات اندازه‌گیری عمل می‌کند، به مرورگر نسبت ابعاد را اطلاع می‌دهد، و این امکان را فراهم می‌کند که فضای مناسبی برای رندر نهایی تصویر رزرو شود. با درج مقدار ارتفاع و عرض روی یک تصویر، مرورگر نسبت ابعاد آن تصویر را می داند. هنگامی که مرورگر با یک بعد واحد مواجه می شود، مانند مثال 50% ما، فضایی را برای تصویر حفظ می کند که به بعد CSS و با بعد دیگر نسبت ابعاد عرض به ارتفاع را حفظ می کند.

<img src="switch.svg" alt="light switch" role="img" width="70" height="112" />

اگر CSS به درستی تنظیم شده باشد تا آنها را پاسخگو کند، تصاویر شما همچنان پاسخگو خواهند بود. بله، مقادیر height و width بدون واحد موجود با CSS لغو خواهند شد. هدف از گنجاندن این ویژگی‌ها، رزرو فضا در نسبت تصویر مناسب، بهبود عملکرد با کاهش تغییر چیدمان است. بارگیری صفحه همچنان تقریباً به همان اندازه طول می کشد، اما وقتی تصویر روی صفحه نمایش داده می شود، رابط کاربری نمی پرد.

سایر ویژگی های تصویر

عنصر <img> همچنین از ویژگی‌های crossorigin ، decoding ، referrerpolicy ، و در مرورگرهای مبتنی بر Blink، ویژگی‌های fetchpriority پشتیبانی می‌کند. به ندرت استفاده می شود، اگر تصویر بخشی از نقشه سمت سرور است، ویژگی ismap boolean را اضافه کنید و <img> در پیوندی برای کاربران بدون دستگاه اشاره گر قرار دهید.

ویژگی ismap در <input type="image" name="imageSubmitName"> ضروری نیست یا حتی پشتیبانی نمی‌شود، زیرا مختصات x و y مکان کلیک در هنگام ارسال فرم ارسال می‌شوند و مقادیر را به نام ورودی اضافه می‌کنند. ، در صورت وجود به عنوان مثال، چیزی مانند &imageSubmitName.x=169&imageSubmitName.y=66 زمانی که کاربر روی تصویر کلیک می کند و آن را ارسال می کند، همراه با فرم ارسال می شود. اگر تصویر دارای ویژگی name نباشد، x و y ارسال می‌شوند: &x=169&y=66 .

درک خود را بررسی کنید

دانش خود را از تصاویر تست کنید.

یک تصویر پیش زمینه همیشه باید چه دو ویژگی داشته باشد؟

size
دوباره امتحان کنید.
alt
درسته!
src
درسته!