با سلام خدمت خوانندگان وب سایت لیزارد وب، قسمت دوازدهم آموزش طراحی وب سایت را شروع می کنیم. کمی با تگ های inline و block آشنا شدیم. اما حالا می خواهیم دقیق تر با آنها آشنا شویم و به آنها استایل بدهیم.
ساده ترین روش تشخیص یک عنصر inline از blockاین است که عنصر inline درون یک عنصر دیگر قرار می گیرد. یک مـثال فیزیکی برای این مسئله این است که شما می توانید درون یک جعبه یک عکس یا چندین عکس را قرار دهید اما درون یک عکس نمی توان چندین جعبه را قرار داد.
از لحاظ فیزیکی نیز این امر امکان پذیر نیست. یک مثال خوب برای این موضوع span است که می تواند گروهی از کلمات را به هم مربوط کند و به آنها استایل دهد:
<P><SPAN CLASS=”FUN”>BUBBLE UNDER</SPAN>IS A GROUP OF DIVING
ENTHUSIASTS BASED IN THE SOUTH-WEST UK WHO MEET UP FOR DIVING
TRIPS IN THE SUMMER MONTHS WHEN THE WEATHER IS GOOD AND THE
BACON ROLLS ARE FLOWING. WE ARRANGE WEEKENDS AWAY AS SMALL
GROUPS TO CUT THE COSTS OF ACCOMMODATION AND TRAVEL AND TO
ENSURE THAT EVERYONE GETS A TRUSTWORTHY DIVE BUDDY.</P>
مثال های دیگری برای عناصر درون خطی:
• em
• Strong
• Cite
• a
به مثال بالا یکبار دیگر نگاه کنید، هر یک از عناصر inline بالا می توانند به جای تگ span در پاراگراف قرار گیرند:
<P><EM>BUBBLE UNDER</EM> IS A GROUP OF DIVING ENTHUSIASTS…</P>
<P><STRONG>BUBBLE UNDER</STRONG> IS A GROUP OF DIVING ENTHUSIASTS </P>
<P><CITE>BUBBLE UNDER</CITE> IS A GROUP OF DIVING ENTHUSIASTS…</P>
<P><A HREF=”HTTP://WWW.BUBBLEUNDER.COM/”>BUBBLE UNDER</A> IS A GROUP OF DIVING ENTHUSIASTS… </P>
باوجود اینکه عنصرimg یک عنصر درون خطی است، اما ما آن را مثل روش های گفته شده در بالا استفاده نمی کنیم. تصویر هیچگونه اطلاعاتی را برای مرورگر تامین نمی کند که به عنوان مثال متن خود را چگونه نمایش بدهد چون یک تصویر تنها یک عکس است و متنی برای نمایش دادن ندارد.
عناصر inline بدون هیچ مشکلی می توانند درون یکدیگر قرار گیرند، به مثال زیر دقت کنید:
<P><SPAN CLASS=”FUN”><A HREF=”HTTP://WWW.BUBBLEUNDER.COM/”>BUBBLE
UNDER</A></SPAN> IS A GROUP OF DIVING ENTHUSIASTS BASED IN
THE SOUTH-WEST UK WHO MEET UP FOR DIVING TRIPS IN THE SUMMER
MONTHS WHEN THE WEATHER IS GOOD AND THE BACON ROLLS ARE
FLOWING. WE ARRANGE WEEKENDS AWAY AS SMALL GROUPS TO CUT THE
COSTS OF ACCOMMODATION AND TRAVEL AND TO ENSURE THAT EVERYONE
GETS A TRUSTWORTHY DIVE BUDDY.</P>
یکی از قوانین XHTML باز و بسته شدن تگ هاست .باید دقت داشته باشید اگر تگی باز شود و بعد از آن تگ های دیگری باز شوند نحوه بسته شدن تگ ها به صورت بر عکس خواهد بود یعنی ابتدا آخرین تگی که باز شده بسته می شود و این روند بستن تگ ها تا آنجایی پیش می رود که به اولین تگی برسیم که باز کرده ایم.
<STRONG>
<EM>
<CITE>
<A HREF=HTTP://WWW.BUBBLEUNDER.COM>
BUBBLE UNDER
</A>
</CITE>
</EM>
</STRONG>
این مدل کد زدن برای تمامی تگ ها و عناصر inline و یا block بکار میرود و هیچ تفاوتی نمی کند.
نکته از مترجم : عناصر block هیچگاه درون عناصر inline قرار نمی گیرند مگر در استثناء هایی در استاندارد HTML5
عناصر Inline یکسری از خصوصیات را می توانند به ارث ببرند اینجا لیست وار برای مروری اجمالی یادآور می شوم:
• تغییر رنگ ( متن یا پس زمینه )
• تغییر خصوصیات فونت (سایز، نوع قلم، سایر خصیصه های استایل دهی به فونت مثل: زیر خط کشیدن و …)
و برای عناصر block این محدودیت را نداریم و عناصر می توانند خصیصه های بیشتری از ابزارهای css را به ارث ببرند:
• به یک متن یا پاراگراف می توان عرض و ارتفاع ثابتی داد.
• برای عناصری که درن یک div قرار گرفته اند می توانید paddingاستفاده کنید تا آنها را از لبه های div اصلی فاصله دهید.
• جابجا کردن یک عنصرblock در هر جای صفحه وب بدون در نظر گرفتن موقعیت آن در صفحه که باعث می شود بسیار چشمگیر ظاهر شود.
نکته مترجم : دقت نمایید برای این که بتوانیم ظاهری بیشتر از ۲ مورد مطرح شده برای عناصر inline به عنصر مورد نظر بدهیم میبایست آن را به block تبدیل نماییم.
به طور پیش فرض عناصر block عرضی معادل با ۱۰۰% فضای اطراف خود را در صفحه سایت اشغال می کنند. حتی اگر که div ای که در برگیرنده آنهاست دارای ارتفاع یا عرض مشخصی باشد. تا اینجای کار تمامی مثال های ما شامل این قضیه می شد اما اگر شما بخواهید می توانید این مقدار را عوض کنید و به جای ۱۰۰% به آن مقدار دیگری را بدهید.
در نظر بگیرید که شما چندین پاراگراف دارید که به طور پیش فرض این پاراگراف ها عرض ۱۰۰% دارند (چرا که block) هستند، و اکنون شما می خواهید تا یکی از این پاراگراف ها بیشتر از بقیه چشمگیر باشد و عرض آن با بقیه متفاوت باشد پس از طریق css به آن پاراگراف استایل خاصی می دهیم.
<P>WE’VE STAYED IN QUITE A FEW CARAVAN PARKS AND CAMP SITES OVER
THE LAST COUPLE OF MONTHS, AND I’VE STARTED TO NOTICE A FEW
THINGS THAT SEEM TO SUGGEST THAT THERE ARE SOME UNWRITTEN
RULES OF STAYING AT THESE PLACES. UNWRITTEN UNTIL NOW, THAT IS.</P>
<P>EVERYONE ELSE ON SITE WILL BE BETTER PREPARED AND BETTER
EQUIPPED THAN YOU. IT’S A FACT. NO MATTER WHAT EXTRAS YOU
MIGHT CARRY, SOMEONE A COUPLE OF PLOTS DOWN WILL STILL HAVE
MORE. UTENSIL ENVY IS RIFE.</P>
<P CLASS=”ATTENTIONGRAB”>WHEN YOU FIRST PARK, THE DISTANCE
BETWEEN THE POWER SUPPLY AND YOUR VAN’S POWER SOCKET WILL BE
PRECISELY 2 INCHES LONGER THAN THE INADEQUATE POWER LEAD THAT
YOU OWN.</P>
<P>ON THE HOTTEST EVENINGS, YOU WILL BE PARKED NEXT TO SOMEONE
WITH A VERY FLASHY VAN THAT’S EQUIPPED WITH AN AIR-CON UNIT.
IT WILL BE FACING YOU, BLOWING OUT HOT AIR AND TAUNTING YOU
WITH ITS EFFICIENT HUM.</P>
تنظیم کردن ارتفاع یک عنصر هم به همان سادگی عرض دادن به آن عنصر بلاک است، اما در بیشتر مواقع عموما از دادن یک ارتفاع ثابت به عناصر پرهیز می شود زیر را باعث می شود تا محدودیتی را برای عناصر خود ایجاد کنید این کار تنها زمانی صورت می گیرد که بدانید تعداد آیتم های موجود در تگ شما محدود است و بنابر این برای اینکه مطمئن شوید ارتفاع آن همواره ثابت خواهد بود به آن می توانید ارتفاع بدهید، به عنوان مثال برای منوی راهبر سایت که معمولا تعداد لینک هایی که در آن قرار می گیرد در بین صفحات مختلف سایت مشخص است.
XHTML زیر را در نظر بگیرید:
<DIV ID=”MAINNAVIGATION”>
<H3>SITE NAVIGATION</H3>
<UL>
<LI><A HREF=”HOME.HTML”>HOME</A></LI>
<LI><A HREF=”RECENT.HTML”>RECENT WORK</A></LI>
<LI><A HREF=”PORTFOLIO.HTML”>PORTFOLIO</A></LI>
<LI><A HREF=”TESTIMONIALS.HTML”>TESTIMONIALS</A></LI>
<LI><A HREF=”CONTACT.HTML”>CONTACT</A></LI>
</UL>
</DIV>
همانطور که در کد بالا می بینید یک تگ div منوی راهبر ما را در برگرفته است و همانطور که می بینید دارای id است به اسم mainnavigation و اگر به خاطر داشته باشید قبلا گفتیم که div یک عنصر بلاک است ، پس می توانیم به آن استایل دهی کرده و css بدهیم و در این میان چون تعداد این لینک ها تقریبا مشخص است می توان برای آن عرض و ارتفاع خاصی را در نظر گرفت، خوب پس بیایید با هم به آن استایل دهیم :
#MAINNAVIGATION {
BACKGROUND-COLOR: #FFCC33;
COLOR: NAVY;
FONT-WEIGHT: BOLD;
WIDTH: 200PX;
HEIGHT: 400PX;
}
همانطور که در کد بالا می بینید من به این منوی رنگ پس زمینه #ffcc33 نیز داده ام تا در زمان نمایش عنصر بلاک را به راحتی تشخیص دهید و ببینید، همچنین به آن عرض و ارتفاع ثابتی داده ام که به شکل یک چهارگوش نمایش یابد.
گفتیم که می توانیم فرض کنیم که تعداد آیتم های منوی ما محدود است پس می توان به آن عرض و ارتفاع داد، اما باید این نکته را در نظر گرفت که بسته به نوع مرورگر نحوه نمایش آن متفاوت است:
– در فایر فاکس ۳ و IE 7 , 8ارتفاع داده شده باعث می شود تا پس زمینه به همان ارتفاعی که مشخص شده به رنک مورد نظر (زرد رنگ ) نمایش یابد و از آنجا به بعد از تگ فوق بیرون می زند.
– اما در مرورگر های قدیمی IE نسخه های ۶ به قبل از آن پس زمینه زرد رنگ بدون در نظر گرفتن اینکه ارتفاع ثابتی دارد اگر تعداد آیتم های آن زیاد تر از ارتفاع داده شده شود توسعه می یابد.
برای عناصر بلاک شما می توانید انواع مختلفی از border (کناره) را به کار ببرید که شامل:
– ضخامت های مختلف برای کناره ها
– سبک دهی های مختلف به کناره ها (خطوط صاف ، نقطه چین و …)
– دادن رنگ های دلخواه
Css ای که می توان برای این مورد به کار برد به ترتیب: border-width و border-style و border-color.
به مثال زیر نگاه کنید تا بهتر آن را درک کنید:
.HIGHLIGHT {
BORDER-WIDTH: 5PX;
BORDER-STYLE: SOLID;
BORDER-COLOR: BLACK;
}
کناره inset
اگر بردر solid به کار شما نمی آید شما می توانید از بردر inset استفاده نمایید.
.HIGHLIGHT {
BORDER-WIDTH: 10PX;
BORDER-STYLE: INSET;
BORDER-COLOR: #999999;
}
رنگی Border :
شما می توانید از رنگ هم در css خود برای کناره ها استفاده کنید تا بردرهایی با دو رنگ و جلوه متفاوت ایجاد کنید:
.HIGHLIGHT {
BORDER-WIDTH: 10PX;
BORDER-STYLE: RIDGE;
BORDER-COLOR: RED;
{