HTML به زبان ساده (جلسه آموزشی دوم)

cover

قبل از هر چیزی باید به‌خاطر نظرها و لطف شما عزیزان تشکر کنم. دو نکته را لازم می‌دانم در ابتدا بگویم: اول اینکه تمام تلاشم را می‌کنم تا هر هفته دو قسمت از آموزش را آماده نمایم (به احتمال زیاد برای روزهای دوشنبه و پنجشنبه).
دوم اینکه آدرس ایمیل من Hamed.zarei@itresan.com است. اگه سوال یا مشکلی داشتید، می‌توانید در بخش نظرها بپرسید و یا حتی ایمیل بزنید.
و اما ادامه آموزش!
اول از همه، جواب تمرین جلسه اول را می‌دهم. همان طور که همگی عزیزان درست حل کردید، برای اضافه کردن یک پاراگراف دیگر کافی است یک بار دیگر از جفت تگ <p> و </p> استفاده کنید.
بنابراین کد به صورت زیر خواهد بود:
<html>
<body>
<p>My first paragraph</p>
<p>My second paragraph</p>
</body>
</html>

سوال!!
به نظر شما در HTML این امکان وجود دارد که در داخل یک تگ، از یک تگ دیگر استفاده کنیم؟!
خب کافی است خودتان امتحان کنید! یک فایل HTML خالی ایجاد کنید (همان‌طور که در جلسه اول گفته شد به‌وسیله نوت پد) و کد بالا را به‌صورت زیر تغییر دهید:
<html>
<body>
<p>My first paragraph <p>My second paragraph </p> </p>
</body>
</html>
فایل رو ذخیره کرده و باز کنید.
حال می‌توانید حتما به سوال بالا جواب بدهید. نه؟! جواب این است که بله! می‌توان تگ‌های HTML را در داخل هم به‌کار برد.
نکته مهم 1: زمانی که تگ‌ها را به‌صورت تو در تو به‌کار می‌برید (مثل کد بالا)، باید یک نکته ساده اما بسیار اساسی را به یاد داشته باشید: تگی که زودتر باز می‌شود، دیرتر بسته می‌شود!
معنی این حرف این است که کد زیر یک کد اشتباه است:
<html>
<body>
<p>
This is my first paragraph.
</body>
</p>
</html>
به این دلیل که تگ body زودتر باز شده و بعد از آن تگ p آمده است. بنابراین ابتدا باید </p> ظاهر شود و سپس </body>. اما در کد بالا اوضاع برعکس است!
نکته مهم 2: اگر پیش‌تر با یکی از زبان‌های برنامه نویسی مثل جاوا یا سی شارپ یا پاسکال یا… کار کرده باشید، حتما با مفهوم کامپایل شدن کد آشنا هستید. اما اگر از قبل تجربه برنامه نویسی نداشته‌اید، باید به زبان ساده بگویم که با کامپایل شدن، کدهای نوشته شده قبل از اجرا شدن، از نظر وجود خطاهای دستوری بررسی می‌شود (مثل اشتباه نوشتن کلمات رزرو شده و…).
از نظر دستوری، کد HTML بالا درست نیست اما باید توجه کنید که HTML فاقد کامپایلر است! یعنی چه؟!!
یک فایل خالی دیگر ایجاد کنید و کدهای بالا را عینا در آن وارد و سپس آن را باز کنید. می‌بینید که مرورگر آن را بدون هیچ مشکل یا پیغام خطایی باز می‌کند.
برای این که کمی موضوع را بیشتر متوجه شوید، این بار کدهای زیر را در فایلی جدید ریخته و باز کنید!
<html>
<body>
<p>This is a paragraph
<p>This is a paragraph
</body>
</html>
این بار هم مرورگرتان کدها را بدون مشکل و به شکل درست نمایش می‌دهد. زیرا مرورگرتان بصورت خود جوش(!) کدهای بالا را به همراه تگ‌های پایانی در نظر می‌گیرد!
اما شما به عنوان یک طراح سایت هیچ گاه نباید به این موضوع تکیه کنید! زمانی که در حال طراحی یک صفحه وب هستید تعداد تگ‌هایی که باید به‌کار ببرید گاهی بسیار زیاد خواهند شد و اگر در استفاده درست آن‌ها دقت نکنید ممکن است ایرادات ناخواسته‌ای در نتیجه به‌وجود بیاید!

زنگ تفریح!!
نوبتی هم باشه نوبته استراحته! پس پنج دقیقه استراحت کنید و بعد ادامه درس! من هم کمی استراحت کنم!
.
.
.
.
.
خب در ادامه این جلسه با مفهوم Attribute یا صفت آشنا می‌شوید.

Attribute چیست؟
• تگ‌های HTML می‌توانند صفت داشته باشند.
• صفت‌ها در واقع، اطلاعات اضافی‌تری درباره یک تگ ارایه می‌دهند!
• صفت‌ها همیشه و همیشه در تگ آغازین مشخص می‌شوند.
• ساختار صفت‌ها به‌صورت زوج‌های “نام/مقدار” بکار می‌روند.
به مثال زیر توجه کنید تا بیشتر متوجه شوید:
لینک‌ها در کد HTML به‌وسیله تگ <a> مشخص می‌شوند. آدرس لینک مورد نظر به‌وسیله صفتی به نام href مشخص می‌شود.
کد زیر را در یک فایل جدید قرار داده و اجرا کنید.
<html>
<body>
<a href=”http://www.google.com”>This is a link</a>
</body>
</html>
نتیجه مشابه تصویر زیر خواهد بود:

pic-1

با کلیک بر روی لینک بالا، به سایت گوگل خواهید رفت!
در واقع، تگ a بدون صفت href نباید بکار برده شود. این href است که مشخص می‌کند آدرس لینک مورد نظر چیست!
برای امتحان کافی است یک بار تگ a را بدون صفت href به‌کار ببرید.
نکته 1: یادتان باشد که در صفت‌ها، مقدار باید همواره بین دو “ (دابل کوتیشن) و یا دو ‘ (سینگل کوتیشن) قرار بگیرد (مانند مثال href در بالا). در واقع صفت‌ها همواره به صورت زیر استفاده می‌شوند:
Name=”value”
یا
Name=’value’
نکته2: در بعضی مواقع خاص، زمانی که خود مقدار value دارای کاراکتر “ است، مجبوریم از تک کوتیشن استفاده کنیم! مثلا:
Name= ’Joe “ShotGun” Nelson’
مهمترین Attributesها:
یکی از مهم‌ترین صفت‌ها، id است که یک نام منحصر به‌فرد برای تگ ایجاد می‌کند. مثال:
<p id=”first_paragraph”> this a paragrapgh. </p>
در مثال بالا، به پاراگراف نام first_paragraph را اختصاص داده‌ایم. با این نام می‌توان در زبان جاوا اسکریپ، جی کوئری و CSS به این پاراگراف دسترسی پیدا کرد!
نکته: زبان جاوا اسکریپ یک زبان Client-side (سمت گیرنده) است که روی مرورگر کاربر اجرا می‌شود. برعکس زبان PHP که server-side است و سمت سرور اجرا شده، نتیجه به مرورگر کاربر منتقل می‌شود.
توجه کنید که جاوا اسکریپت هیچ ارتباطی با زبان برنامه نویسی جاوا ندارد!
اگر با جاوا اسکریپت، جی کوئری، پی اچ پی، سی اس اس آشنا نیستند، نگران نباشید. برای یاد گرفتن این‌ها، ابتدا باید HTML را به‌خوبی بشناسید. ضمن اینکه، به امید خدا و اگر عمری باقی باشد پس از پایان یافتن این سری آموزش به سراغ این‌ها هم خواهیم رفت.

HTML به زبان ساده (جلسه آموزشی اول)

[divide style=”2″]

راستی، اگر فناوری اطلاعات در زندگی‌تون اهمیت زیادی داره، پیشنهاد می‌کنم تولبار آی‌تی را حتما نصب کنید: [نصب تولبار]

13 در مورد “HTML به زبان ساده (جلسه آموزشی دوم)”

  1. خداقوت .
    واقعا آمزش ها عالی هستن.
    به نظرم هرکی با هر سطح اطلاعات میتونه از این آموزش های بی نقص شما استفاده کنه.
    موفق و پیروز باشید

  2. سلام اگه ممکنه منو راهنمایى کنید من برنامه htmlساخت صفحه وب را مى نویسم مسیر عکس هم مى دهم ولى در موقع اجرا خود کدهایى که نوشته بودم را به جاى اجرا در وب نشان مى دهدیعنى تنها کدها دیده مىشود خیلى عجله دارم اگر ممکن هست زود جواب بدید ممنونتون میشم

  3. راستش من خوب متوجه نشدم تو قسمته ایدی ای که ساختید….مثلا وقتی رویthis is a paragraphکلیک کنیم اون پاراگراف که توی کوتیشنه باز میشه؟؟؟:-؟
    ممنون میشم اگه جواب بدید:)

  4. چندتا سوال دیگه : (یادم رف تو کامنت اول بپرسم! بوخشید!)

    1) برای استفاده در جاهایی دیگه از پاراگرافی که اسمشو گذاشتیم first_paragraph باید چطور عمل کنید؟ یعنی از چه کدی استفاده کنیم تا فراخوانی بشه؟ اصلا کجاها میشه ازش استفاده کرد؟ و چه مدلی؟

    2) هرموقع از id استفاده کردیم یعنی اینکه بهش اسم دادیم یا آدرس یا بخشی از حافظه رو بهش اختصاص دادیم یا چیزه دیگه؟

    3) منظور از ” سمت گیرنده ” و ” سمت سرور ” چیست؟
    4) چطور میتونیم ارور ها بگیرم وقتی که مرورگر هیچ ارور ی نمیده و یا در زمان ذخیره هم ارور نمیده؟
    ببخشید که این همه سوال پیچتون کردم!!
    خیلی خوب میشه که اینو یادمون بدین و بعدش بریم سراغ برنامه نویسی های دیگه

    خیلی چیزای جالبی این دفه یاد گرفتم
    مشتاق دیدن آموزش بعدی هستیم
    خسته نباشید که وقت گذاشتید

    1. حامد زارعی

      سلام…
      مرسی آرزو خانوم.
      اگه اجازه بدی جواب این سوال ها رو توی جلسه سوم میدم. شاید سوال خیلی های دیگه هم باشه

  5. درود

    این سری هم خیلی جالب بود.

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

    1)ما میتونیم دابل کوتیشن رو به جای سینگل کوتیشن هم استفاده کنیم و برعکس حالا هر جا که دلمون خواست!!!

    2) برای مورده خاص هم یعنی اگه بخواهیم دابل کوتیشن رو تو صفحه نمایش نشونش بده از سینگل کوتیشن برای کل عبارت استفاده میکنم!!

    عایا درست گفتم؟!؟!!؟

    1. حامد زارعی

      سلام و ممنون بابت لطفت!
      درست متوجه نشدم کدوم قسمت رو می گی!
      اگه منظورت استفاده از “تک کوتیشن” هستش باید بگم که یه زمانی که متن ما خودش دارای کاراکتر دابل کوتیشن (“) هستش! خب وقتی خود متن شامل ” باشد و ما هم در پایان متن از ” استفاده کنیم، مرورگر گیج میشه!!!
      چرا؟! چون مرورگر زمان خواندن کدها برای نمایش، وقتی با اولین ” برخورد کرد، فکر می کند متن اینجا تمام می شود درصورتی این طور نیست! مثال:
      name = “amir ” hossein”.
      در مثال بالا، مرورگر وقتی به name می رسه انتظار یک رشته بین دو کاراکتر ” را دارد! اما اتفاقی می افته اینه که بعد از خوندن amir، به کاراکتر ” می رسه و تصور می کنه متن اینجا تموم میشه! پس مقدار name برابر amir میشه! بعد از اون، به کاراکترهای hossein می رسه و از خودش می پرسه پس این کاراکترها چی هستن؟؟؟!!!!!!!!!!!!
      برای این که این اتفاقاهای ناخواسته نیوفته، از تک کوتیشن استفاده می شه!

      امیدوارم خوب توضیح داده باشم! ^_^

دیدگاه‌ خود را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

به بالا بروید