ستÙÙ ÙÙØ±Ø§Øª Ø³ÙØ¯ html تگâÙØ§ (tag) ÙØ³ØªÙد.
Ø·Ø¨Ù Ù Ø¯Ù Ø´ÛØ¡Ú¯Ø±Ø§Û Ø³ÙØ¯ (Document Object Model ÛØ§ DOM)Ø ÙØ± تگ HTML ÛÚ© Ø´ÛØ¡ است. تگâÙØ§Û داخÙÛ âÙØ±Ø²ÙداÙÙâ ØªÚ¯âÙØ§Û Ø¯Ø±Ø¨Ø±Ú¯ÛØ±ÙØ¯Ù ÙØ³ØªÙد. ٠ت٠داخ٠تگ ÙÛØ² ÛÚ© Ø´ÛØ¡ است.
Ù٠٠اÛÙ Ø§Ø´ÛØ§Ø¡ با Ø§Ø³ØªÙØ§Ø¯Ù از Ø¬Ø§ÙØ§Ø§Ø³Ú©Ø±Ûپت ÙØ§Ø¨Ù دسترس ÙØ³ØªÙد ٠٠ا Ù ÛâØªÙØ§ÙÛ٠از Ø¢ÙâÙØ§ Ø¨Ø±Ø§Û ØªØºÛÛØ± ØµÙØÙ Ø§Ø³ØªÙØ§Ø¯Ù Ú©ÙÛÙ .
ب٠عÙÙØ§Ù Ù
Ø«Ø§ÙØ document.body Ø´ÛØ¡Ø§Û است ک٠تگ <body> را ÙØ´Ø§Ù Ù
ÛâØ¯ÙØ¯.
با Ø§Ø¬Ø±Ø§Û Ø§ÛÙ Ú©Ø¯Ø <body> ب٠Ù
دت 3 ثاÙÛÙ ÙØ±Ù
ز Ù
ÛâØ´ÙØ¯:
document.body.style.background = 'red'; // پس زÙ
ÛÙ٠را ÙØ±Ù
ز Ú©Ù
setTimeout(() => document.body.style.background = '', 3000); // برگرد
در اÛÙØ¬Ø§ Ù
ا از style.background Ø¨Ø±Ø§Û ØªØºÛÛØ± رÙÚ¯ پس زÙ
ÛÙÙ document.body Ø§Ø³ØªÙØ§Ø¯Ù کردÛÙ
Ø Ø§Ù
ا ÙÛÚÚ¯ÛâÙØ§Û Ø²ÛØ§Ø¯Ù دÛÚ¯Ø±Û ÙØ¬Ùد Ø¯Ø§Ø±Ø¯Ø Ù
اÙÙØ¯:
innerHTMLâ HTML Ù ØØªÙÛØ§ØªÙ گرÙoffsetWidthâ Ø¹Ø±Ø¶ گر٠(بر ØØ³Ø¨ Ù¾ÛکسÙ)- ØºÛØ±Ù Ù â¦
Ø¨Ù Ø²ÙØ¯Û راÙâÙØ§Û Ø¨ÛØ´ØªØ±Û Ø¨Ø±Ø§Û Ø¯Ø³ØªÚ©Ø§Ø±Û DOM ÛØ§Ø¯ Ø®ÙØ§ÙÛÙ Ú¯Ø±ÙØªØ ا٠ا ابتدا Ø¨Ø§ÛØ¯ ساختار آ٠را بداÙÛÙ .
ÙÙ ÙÙÙ Ø§Û Ø§Ø² DOM
Ø¨ÛØ§ÛÛØ¯ با Ø³ÙØ¯ Ø³Ø§Ø¯Ù Ø²ÛØ± Ø´Ø±ÙØ¹ Ú©ÙÛÙ :
<!DOCTYPE HTML>
<html>
<head>
<title>Ø¯Ø±Ø¨Ø§Ø±Ù Ú¯ÙØ²Ù Ø´Ù
اÙÛ</title>
</head>
<body>
ØÙÛÙØª Ø¯Ø±Ø¨Ø§Ø±Ù Ú¯ÙØ²Ù Ø´Ù
اÙÛ.
</body>
</html>
Ø´ÛØ¡ DOM Ø³ÙØ¯ HTML را ب٠عÙÙØ§Ù ÛÚ© ساختار Ø¯Ø±Ø®ØªÛ Ø§Ø² تگâÙØ§ ÙØ´Ø§Ù Ù ÛâØ¯ÙØ¯. اÛÙÚ¯ÙÙÙ Ø¨Ù ÙØ¸Ø± Ù ÛâØ±Ø³Ø¯:
در تصÙÛØ± Ø¨Ø§ÙØ§Ø Ù ÛâØªÙØ§ÙÛØ¯ رÙÛ Ú¯Ø±ÙâÙØ§Û Ø¹ÙØµØ± Ú©ÙÛÚ© Ú©ÙÛØ¯ Ù ÙØ±Ø²Ùدا٠آÙâÙØ§ باز Ù ÛâØ´ÙÙØ¯.
ÙØ± گرÙâÛ Ø¯Ø±Ø®Øª ÛÚ© Ø´ÛØ¡ است.
تگâÙØ§ گرÙâÙØ§Û Ø¹ÙØµØ± (Ø¹ÙØ§ØµØ±) ÙØ³ØªÙد ٠ساختار Ø¯Ø±Ø®ØªÛ Ø±Ø§ تشکÛÙ Ù
ÛâØ¯ÙÙØ¯: <html> در Ø±ÛØ´Ù Ø§Ø³ØªØ Ø³Ù¾Ø³ <head> Ù <body> ÙØ±Ø²ÙØ¯Ø§Ù Ø¢Ù ÙØ³ØªÙد Ù â¦.
Ù
ØªÙ Ø¯Ø§Ø®Ù Ø¹ÙØ§ØµØ± گرÙâÙØ§Û Ù
تÙÛ (text nodes) را تشکÛÙ Ù
ÛâØ¯ÙØ¯ ک٠با عÙÙØ§Ù text# Ø¨Ø±ÚØ³Ø¨âÚ¯Ø°Ø§Ø±Û Ø´Ø¯ÙâØ§ÙØ¯. ÛÚ© گر٠Ù
تÙÛ ÙÙØ· شاÙ
Ù ÛÚ© رشت٠است. Ù
Ù
ک٠است ÙØ±Ø²ÙØ¯Û ÙØ¯Ø§Ø´ØªÙ باشد Ù ÙÙ
ÛØ´Ù برگ درخت باشد.
ب٠عÙÙØ§Ù Ù
ثا٠تگ٠<title> Ù
ت٠"دربارÙâÛ Ú¯ÙØ²Ù Ø´Ù
اÙÛ" را دارد.
ÙØ·ÙØ§Ù Ø¨Ù Ú©Ø§Ø±Ø§Ú©ØªØ±ÙØ§Û خاص در گرÙâÙØ§Û Ù ØªÙ ØªÙØ¬Ù Ú©ÙÛØ¯:
- ÛÚ© خط Ø¬Ø¯ÛØ¯:
âµ(در Ø¬Ø§ÙØ§Ø§Ø³Ú©Ø±Ûپت Ø¨Ù ØµÙØ±Øªn\Ø´ÙØ§Ø®ØªÙ Ù ÛâØ´ÙØ¯.) - ÛÚ© ÙØ§ØµÙÙ(space) :
â£
ÙØ§ØµÙÙ ÙØ§ Ù Ø®Ø·ÙØ· Ø¬Ø¯ÛØ¯ Ú©Ø§Ø±Ø§Ú©ØªØ±ÙØ§Û کاÙ
ÙØ§Ù Ù
Ø¹ØªØ¨Ø±Û ÙØ³ØªÙØ¯Ø Ù
اÙÙØ¯ ØØ±Ù٠٠اعداد. Ø¢ÙâÙØ§ گرÙâÙØ§Û Ù
تÙÛ Ø±Ø§ تشکÛÙ Ù
ÛâØ¯ÙÙØ¯ Ù Ø¨Ø®Ø´Û Ø§Ø² DOM Ù
ÛâØ´ÙÙØ¯. Ø¨ÙØ§Ø¨Ø±Ø§ÛÙØ Ø¨Ø±Ø§Û Ù
Ø«Ø§ÙØ در Ù
Ø«Ø§Ù Ø¨Ø§ÙØ§Ø تگ <head> ØØ§ÙÛ ÚÙØ¯ ÙØ§ØµÙÙ ÙØ¨Ù از <title> Ø§Ø³ØªØ Ù Ø¢Ù Ù
ت٠ب٠ÛÚ© گر٠text# تبدÛÙ Ù
ÛâØ´ÙØ¯ (Ú©Ù ÙÙØ· ØØ§ÙÛ ÛÚ© خط Ø¬Ø¯ÛØ¯ Ù ÚÙØ¯ ÙØ§ØµÙ٠است).
ÙÙØ· Ø¯Ù Ø§Ø³ØªØ«ÙØ§Ø¡ Ø³Ø·Ø Ø¨Ø§ÙØ§ ÙØ¬Ùد دارد:
- ÙØ§ØµÙÙâÙØ§ Ù Ø®Ø·ÙØ· Ø¬Ø¯ÛØ¯ ÙØ¨Ù از
<head>Ø¨Ù Ø¯ÙØ§ÛÙ ØªØ§Ø±ÛØ®Û ÙØ§Ø¯ÛØ¯Ù Ú¯Ø±ÙØªÙ Ù ÛâØ´ÙÙØ¯. - اگر ÚÛØ²Û را بعد از
</body>ÙØ±Ø§Ø± دÙÛÙ Ø Ø¯Ø± Ù¾Ø§ÛØ§Ù Ø¨Ù Ø·ÙØ± Ø®ÙØ¯Ú©Ø§Ø± ب٠داخÙbodyÙ ÙØªÙÙ Ù ÛâØ´ÙØ¯Ø Ø²ÛØ±Ø§ ٠شخصات HTML Ø§ÛØ¬Ø§Ø¨ Ù ÛâÚ©ÙØ¯ Ú©Ù ØªÙ Ø§Ù Ù ØØªÙا Ø¨Ø§ÛØ¯ داخÙ<body>باشد. Ø¨ÙØ§Ø¨Ø±Ø§ÛÙ ÙÛÚ ÙØ§ØµÙÙâØ§Û Ø¨Ø¹Ø¯ از</body>ÙØ¬Ùد ÙØ¯Ø§Ø±Ø¯.
در Ù ÙØ§Ø±Ø¯ دÛگر ÙÙ Ù ÚÛØ² سر راست است â Ø§Ú¯Ø± در Ø³ÙØ¯ ÙØ§ØµÙÙ ÙØ¬Ùد داشت٠باشد(دÙÛÙØ§Ù ٠اÙÙØ¯ ÙØ± کاراکترÛ)Ø Ø¢ÙâÙØ§ ب٠گرÙâÙØ§Û ٠تÙÛ Ø¯Ø± DOM تبدÛÙ Ù ÛâØ´ÙÙØ¯Ø ٠اگر Ø¢ÙÙØ§ را ØØ°Ù Ú©ÙÛÙ Ø ÙØ¬Ùد ÙØ®ÙاÙÙØ¯ داشت.
در اÛÙØ¬Ø§ ÙÛÚ Ú¯Ø±Ù Ù ØªÙÛ ÙÙØ·-ÙØ§ØµÙÙ ÙØ¬Ùد ÙØ¯Ø§Ø±Ø¯:
<!DOCTYPE HTML>
<html><head><title>دربارÙâÛ Ú¯ÙØ²Ù Ø´Ù
اÙÛ</title></head><body>ØÙÛÙØª در Ù
ÙØ±Ø¯ Ú¯ÙØ²Ù Ø´Ù
اÙÛ.</body></html>
Ø§Ø¨Ø²Ø§Ø±ÙØ§Û Ù Ø±ÙØ±Ú¯Ø± (Ø¨Ù Ø²ÙØ¯Û Ù¾ÙØ´Ø´ Ø¯Ø§Ø¯Ù Ø®ÙØ§Ùد شد) ک٠با DOM کار Ù ÛâÚ©ÙÙØ¯ ٠ع٠ÙÙØ§Ù ÙØ§ØµÙÙâÙØ§ را در ابتدا/Ø§ÙØªÙØ§Û Ù ØªÙ Ù Ú¯Ø±ÙâÙØ§Û ٠تÙ٠خاÙÛ٠بÛ٠تگâÙØ§ (Ø®Ø·ÙØ· Ø¬Ø¯ÛØ¯) را ÙØ´Ø§Ù ÙÙ ÛâØ¯ÙÙØ¯.
Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù(Ø§Ø¨Ø²Ø§Ø±ÙØ§Û Ù Ø±ÙØ±Ú¯Ø±) از اÛ٠طرÛÙ ÙØ¶Ø§Û ØµÙØÙ Ø±Ø§ ØÙظ Ù ÛâÚ©ÙÙØ¯.
در ادا٠ÙâÛ ØªØµØ§ÙÛØ± DOM Ø Ú¯Ø§ÙÛ Ø§ÙÙØ§Øª ز٠اÙÛ Ú©Ù ÙØ§Ù Ø±Ø¨ÙØ· ÙØ³ØªÙد Ø¢ÙâÙØ§ را ØØ°Ù Ù ÛâÚ©ÙÛÙ . ÚÙÛÙ ÙØ¶Ø§ÙاÛÛ Ù Ø¹Ù ÙÙØ§Ù بر ÙØÙÙ ÙÙ Ø§ÛØ´ Ø³ÙØ¯ ØªØ£Ø«ÛØ± ÙÙ Ûâگذارد.
تصØÛØ Ø®ÙØ¯Ú©Ø§Ø±
اگر Ù Ø±ÙØ±Ú¯Ø± با HTML ÙØ§Ø¯Ø±Ø³Øª Ù ÙØ§Ø¬Ù Ø´ÙØ¯Ø ÙÙگا٠ساخت DOM Ø¨Ù Ø·ÙØ± Ø®ÙØ¯Ú©Ø§Ø± آ٠را تصØÛØ Ù ÛâÚ©ÙØ¯.
ب٠عÙÙØ§Ù Ù
Ø«Ø§ÙØ تگ Ø¨Ø§ÙØ§ ÙÙ
ÛØ´Ù <html> است. ØØªÛ اگر در Ø³ÙØ¯ ÙØ¬Ùد ÙØ¯Ø§Ø´ØªÙ Ø¨Ø§Ø´Ø¯Ø Ø¯Ø± DOM ÙØ¬Ùد Ø®ÙØ§Ùد Ø¯Ø§Ø´ØªØ Ø²ÛØ±Ø§ Ù
Ø±ÙØ±Ú¯Ø± آ٠را Ø§ÛØ¬Ø§Ø¯ Ù
ÛâÚ©ÙØ¯. <body> ÙÙ
ÙÙ
ÛÙØ·Ùر.
ب٠عÙÙØ§Ù Ù
Ø«Ø§ÙØ اگر ÙØ§ÛÙ HTML تÙÙØ§ Ú©ÙÙ
Ù "Hello" Ø¨Ø§Ø´Ø¯Ø Ù
Ø±ÙØ±Ú¯Ø± آ٠را درÙÙ <html> Ù <body> Ù
ÛâÙ¾ÛÚØ¯ Ù <head> Ø¶Ø±ÙØ±Û را اضاÙÙ Ù
ÛâÚ©ÙØ¯ Ù DOM اÛÙØ·Ùر Ø®ÙØ§Ùد Ø¨ÙØ¯:
ÙÙگا٠تÙÙÛØ¯ DOMØ Ù Ø±ÙØ±Ú¯Ø±Ùا Ø¨Ù Ø·ÙØ± Ø®ÙØ¯Ú©Ø§Ø± Ø®Ø·Ø§ÙØ§Û Ø³ÙØ¯ را پردازش Ù ÛâÚ©ÙÙØ¯Ø تگâÙØ§ را Ù ÛâØ¨ÙØ¯Ùد Ù ØºÛØ±Ù.
Ø³ÙØ¯Û با تگâÙØ§Û Ø¨Ø³ØªÙ ÙØ´Ø¯Ù:
<p>Ø³ÙØ§Ù
<li>Ù
اÙ
اÙ
<li>Ù
<li>بابا
â¦ÙÙØªÛ Ù Ø±ÙØ±Ú¯Ø± تگâÙØ§ را Ù ÛâØ®ÙØ§Ùد Ù ÙØ³Ù تâÙØ§Û از دست Ø±ÙØªÙ را Ø¨Ø§Ø²ÛØ§Ø¨Û Ù ÛâÚ©ÙØ¯Ø ب٠ÛÚ© DOM ٠ع٠ÙÙÛ ØªØ¨Ø¯ÛÙ Ù ÛâØ´ÙØ¯:
<tbody> Ø¯Ø§Ø±ÙØ¯.ÛÚ© âÙ
ÙØ±Ø¯ Ø®Ø§Øµâ Ø¬Ø§ÙØ¨Ø Ø¬Ø¯Ø§Ù٠است. بر اساس Ù
شخصات DOMØ Ø¢ÙÙØ§ Ø¨Ø§ÛØ¯ تگ <tbody> Ø¯Ø§Ø´ØªÙ Ø¨Ø§Ø´ÙØ¯Ø اÙ
ا Ù
ت٠HTML Ù
Ù
ک٠است آ٠را از ÙÙÙ
Ø§ÙØ¯Ø§Ø®ØªÙ باشد. سپس Ù
Ø±ÙØ±Ú¯Ø± Ø¨Ù ØµÙØ±Øª Ø®ÙØ¯Ú©Ø§Ø± <tbody> را در DOM Ø§ÛØ¬Ø§Ø¯ Ù
ÛâÚ©ÙØ¯.
Ø¨Ø±Ø§Û HTML:
<table id="table"><tr><td>1</td></tr></table>
ساختار DOM اÛÙØ·Ùر Ø®ÙØ§Ùد Ø¨ÙØ¯:
Ù
ÛâØ¨ÛÙÛØ <tbody> از ÙØ§Ú©Ø¬Ø§Ø¢Ø¨Ø§Ø¯ Ø¸Ø§ÙØ± شد. ÙÙگاÙ
کار با جداÙÙ Ø¨Ø§ÛØ¯ اÛ٠را در ÙØ¸Ø± داشت٠باشÛÙ
تا از غاÙÙÚ¯ÛØ±Û جÙÙÚ¯ÛØ±Û Ú©ÙÛÙ
.
اÙÙØ§Ø¹ دÛگر گرÙâÙØ§
Ø¹ÙØ§Ù٠بر Ø¹ÙØ§ØµØ± ٠گرÙâÙØ§Û Ù ØªÙØ اÙÙØ§Ø¹ دÛگر گرÙâÙØ§ ÙÛØ² ÙØ¬Ùد دارد.
ب٠عÙÙØ§Ù Ù Ø«Ø§ÙØ Ú©Ø§Ù ÙØªâÙØ§:
<!DOCTYPE HTML>
<html>
<body>
ØÙÛÙØª در Ù
ÙØ±Ø¯ Ú¯ÙØ²Ù.
<ol>
<li>Ú¯ÙØ²Ù Ø´Ù
اÙÛ Ø¨Ø§ÙÙØ´ است</li>
<!-- comment -->
<li>...Ù ØÛÙØ§ÙÛ ØÛÙÙâگر!</li>
</ol>
</body>
</html>
Ù
ا Ù
ÛâØªÙØ§ÙÛÙ
در اÛÙØ¬Ø§ ÛÚ© ÙÙØ¹ Ú¯Ø±Ù Ø¯Ø±Ø®ØªÛ Ø¬Ø¯ÛØ¯ ببÛÙÛÙ
â گر٠commentØ Ø¨Ø§ Ø¨Ø±ÚØ³Ø¨ comment#Ø Ø¨Û٠د٠گر٠Ù
تÙ.
٠٠ک٠است Ùکر Ú©ÙÛÙ â ÚØ±Ø§ ÛÚ© comment ب٠DOM اضاÙÙ Ø´Ø¯Ù Ø§Ø³ØªØ Ø¨Ù ÙÛÚ ÙØ¬Ù بر ÙÙ Ø§ÛØ´ Ø¨ØµØ±Û ØªØ£Ø«ÛØ± ÙÙ Ûâگذارد. ا٠ا ÛÚ© ÙØ§ÙÙÙ ÙØ¬Ùد دارد â Ø§Ú¯Ø± ÚÛØ²Û در HTML Ø§Ø³ØªØ Ø¨Ø§ÛØ¯ در درخت DOM ÙÛØ² باشد.
ÙÙ Ù ÚÛØ² در HTMLØ ØØªÛ commentsØ Ø¨Ø®Ø´Û Ø§Ø² DOM Ù ÛâØ´ÙØ¯.
ØØªÛ Ø¯Ø³ØªÙØ± <...DOCTYPE!> در ÙÙ
Ø§Ù Ø§Ø¨ØªØ¯Ø§Û HTML ÙÛØ² ÛÚ© گر٠DOM است. درست ÙØ¨Ù از <html> در درخت DOM ÙØ±Ø§Ø± دارد. تعداد Ú©Ù
Û Ø§Ø² Ù
ردÙ
در Ù
ÙØ±Ø¯ Ø¢Ù Ù
ÛâØ¯Ø§ÙÙØ¯. Ù
ا ÙØ±Ø§Ø± ÙÛØ³Øª ب٠آ٠دست بزÙÛÙ
Ø ØØªÛ آ٠را رÙÛ ÙÙ
ÙØ¯Ø§Ø±Ùا ÙÙ
ÛâÚ©Ø´ÛÙ
Ø Ø§Ù
ا ÙØ¬Ùد داردâ¦
Ø´Û document Ú©Ù Ú©Ù Ø³ÙØ¯ را ÙØ´Ø§Ù Ù
ÛâØ¯ÙØ¯Ø Ø¨Ù Ø·ÙØ± رسÙ
ÛØ ÛÚ© گر٠DOM ÙÛØ² ÙØ³Øª.
12 ÙÙØ¹ Ú¯Ø±Ù ÙØ¬Ùد دارد. در ع٠٠٠ا ٠ع٠ÙÙØ§ با 4 Ù ÙØ±Ø¯ از Ø¢ÙÙØ§ کار Ù ÛâÚ©ÙÛÙ 12 node types :
documentâ âDOMâ ÙÙØ·ÙâÛ ÙØ±Ùد بÙ- (گرÙâÙØ§Û Ø¹ÙØµØ±) â Ø¨ÙÙÚ©âÙØ§Û ساختار Ø¯Ø±Ø®ØªÛ , HTML تگâÙØ§Û
- ØØ§ÙÛ Ù ØªÙ â (گرÙâÙØ§Û ٠تÙ)
- (Ú©Ø§Ù ÙØªâÙØ§) â Ø¨Ø®ÙØ§ÙØ¯ DOM گاÙÛ Ø§ÙÙØ§Øª Ù ÛâØªÙØ§ÙÛÙ Ø§Ø·ÙØ§Ø¹Ø§Øª را در Ø¢ÙØ¬Ø§ ÙØ±Ø§Ø± دÙÛÙ Ø ÙØ´Ø§Ù داد٠ÙÙ ÛâØ´ÙØ¯Ø ا٠ا Ø¬Ø§ÙØ§Ø§Ø³Ú©Ø±Ûپت Ù ÛâØªÙØ§Ùد آ٠را از
Ø®ÙØ¯ØªØ§Ù آ٠را ببÛÙÛØ¯
Ø¨Ø±Ø§Û Ø¯ÛØ¯Ù ساختار Dom Ø¨Ù ØµÙØ±Øª بÛâÙÙÙÙ (real-time)Ø Live DOM Viewer را Ø§Ù ØªØØ§Ù Ú©ÙÛØ¯. ÙÙØ· در Ø³ÙØ¯ تاÛÙ¾ Ú©ÙÛØ¯ ٠درجا ب٠عÙÙØ§Ù ÛÚ© DOM ÙØ´Ø§Ù Ø¯Ø§Ø¯Ù Ø®ÙØ§Ùد شد.
را٠دÛگر Ø¨Ø±Ø§Û Ú©Ø´Ù DOM Ø§Ø³ØªÙØ§Ø¯Ù از Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù Ù Ø±ÙØ±Ú¯Ø± است. در ÙØ§ÙØ¹Ø Ø§ÛÙ Ù٠ا٠ÚÛØ²Û است ک٠٠ا ÙÙÚ¯Ø§Ù ØªÙØ³Ø¹Ù Ø§Ø³ØªÙØ§Ø¯Ù Ù ÛâÚ©ÙÛÙ .
Ø¨Ø±Ø§Û Ø§ÙØ¬Ø§Ù اÛÙ Ú©Ø§Ø±ØØ§ÛÙ ØµÙØÙ Ø±Ø§ باز Ú©ÙÛØ¯ elk.html, Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù Ù Ø±ÙØ±Ú¯Ø± را ÙØ¹Ø§Ù Ú©ÙÛØ¯ ٠ب٠زباÙÙ Elements برÙÛØ¯.
Ø¨Ø§ÛØ¯ شبÛ٠ب٠اÛ٠باشÙ:
Ù ÛâØªÙØ§ÙÛØ¯ DOM را ببÛÙÛØ¯Ø رÙÛ Ø¹ÙØ§ØµØ± Ú©ÙÛÚ© Ú©ÙÛØ¯Ø Ø¬Ø²Ø¦ÛØ§Øª Ø¢ÙÙØ§ را ببÛÙÛØ¯ Ù ØºÛØ±Ù.
ÙØ·ÙØ§Ù ØªÙØ¬Ù Ø¯Ø§Ø´ØªÙ Ø¨Ø§Ø´ÛØ¯ ک٠ساختار DOM در Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù ساد٠شد٠است. گرÙâÙØ§Û ٠ت٠ÙÙØ· Ø¨Ù ØµÙØ±Øª Ù ØªÙ ÙØ´Ø§Ù داد٠٠ÛâØ´ÙÙØ¯. Ù ÙÛÚ Ú¯Ø±Ù Ù ØªÙÛ âØ®Ø§ÙÛâ (ÙÙØ· ÙØ§ØµÙÙ) ÙØ¬Ùد ÙØ¯Ø§Ø±Ø¯. اÛÙ Ø®ÙØ¨ Ø§Ø³ØªØ Ø²ÛØ±Ø§ Ø§ØºÙØ¨ ٠ا ب٠گرÙâÙØ§Û Ø¹ÙØµØ± Ø¹ÙØ§ÙÙâÙ ÙØ¯ÛÙ â¦
با Ú©ÙÛÚ© رÙÛ Ø¯Ú©Ù ÙâÛ Ø¯Ø± Ú¯ÙØ´Ù س٠ت ÚÙ¾ Ø¨Ø§ÙØ§ Ù ÛâØªÙØ§ÙÛ٠با Ø§Ø³ØªÙØ§Ø¯Ù از Ù Ø§ÙØ³ (ÛØ§ Ø³Ø§ÛØ± دستگاÙâÙØ§Û اشارÙâگر) ÛÚ© گر٠از ØµÙØÙ ÙØ¨ Ø§ÙØªØ®Ø§Ø¨ کرد٠٠آ٠را Â«Ø¨Ø§Ø²Ø±Ø³Û (inspect)» Ú©ÙÛÙ (در زباÙÙ Elements ب٠آ٠scroll Ú©ÙÛØ¯). ÙÙØªÛ ÛÚ© ØµÙØÙ HTML بزرگ (Ù DOM بزرگ Ù Ø±Ø¨ÙØ·Ù) دارÛÙ Ù Ù ÛâØ®ÙØ§ÙÛÙ Ø¬Ø§Û ÛÚ© Ø¹ÙØµØ± خاص را در آ٠ببÛÙÛÙ Ø Ø¹Ø§ÙÛ Ø¹Ù Ù Ù ÛâÚ©ÙØ¯.
را٠دÛگر Ø¨Ø±Ø§Û Ø§ÙØ¬Ø§Ù اÛ٠کار ÙÙØ· Ú©ÙÛÚ© راست بر رÙÛ ÛÚ© ØµÙØÙ ÙØ¨ Ù Ø§ÙØªØ®Ø§Ø¨ âInspectâ Ø¯Ø± Ù ÙÙÛ context است.
در ÙØ³Ù ت س٠ت راست Ø§Ø¨Ø²Ø§Ø±ÙØ§ Ø²ÛØ± زباÙÙâÙØ§Û Ø²ÛØ± ÙØ¬Ùد دارد:
- Styles â Ù ÛâØªÙØ§ÙÛÙ CSS را ببÛÙÛÙ Ú©Ù ÙØ§ÙÙÙ Ø¨Ù ÙØ§ÙÙ٠بر Ø¹ÙØµØ± ÙØ¹ÙÛ Ø§Ø¹Ù Ø§Ù Ù ÛâØ´ÙØ¯Ø از ج٠ÙÙ ÙÙØ§ÙÛ٠داخÙÛ (Ø®Ø§Ú©Ø³ØªØ±Û Ø±ÙÚ¯). ØªÙØ±Ûبا٠ÙÙ Ù ÚÛØ² را Ù ÛâØªÙØ§Ù در Ø¬Ø§Û Ø®ÙØ¯ ÙÛØ±Ø§ÛØ´ Ú©Ø±Ø¯Ø Ø§Ø² ج٠Ù٠ابعاد/ØØ§Ø´ÛÙ ÙØ§Û Ø¨ÛØ±ÙÙÛ/ØØ§Ø´ÛÙâÙØ§Û داخÙÛ Ø§Ø² طرÛ٠جعبÙâÛ Ø²ÛØ±ÛÙ.
- Computed â Ø¨Ø±Ø§Û Ù Ø´Ø§ÙØ¯Ù CSS اع٠ا٠شد٠بر رÙÛ Ø¹ÙØµØ± ØªÙØ³Ø· ÙÛÚÚ¯Û: Ø¨Ø±Ø§Û ÙØ± ÙÛÚÚ¯Û Ù ÛâØªÙØ§ÙÛÙ ÙØ§ÙÙÙÛ Ú©Ù Ø¨Ù Ø¢Ù Ù ÛâØ¯ÙØ¯ را ببÛÙÛÙ (از ج٠ÙÙ ÙØ±Ø§Ø«Øª CSS ٠از اÛ٠دست Ù ÙØ§Ø±Ø¯).
- Event Listeners â Ø¨Ø±Ø§Û Ø¯ÛØ¯Ù event listener Ù ØªØµÙ Ø¨Ù Ø¹ÙØ§ØµØ± DOM (٠ا Ø¢ÙâÙØ§ را در ÙØ³Ù ت Ø¨Ø¹Ø¯Û Ø¢Ù ÙØ²Ø´ Ù¾ÙØ´Ø´ Ø®ÙØ§ÙÛ٠داد).
- â¦Ù ØºÛØ±Ù.
Ø¨ÙØªØ±ÛÙ Ø±Ø§Ù Ø¨Ø±Ø§Û Ù Ø·Ø§ÙØ¹Ù Ø¢ÙÙØ§ Ú©ÙÛÚ© کرد٠در داخ٠آÙÙØ§ است. اکثر Ù ÙØ§Ø¯Ûر درجا ÙØ§Ø¨Ù ÙÛØ±Ø§ÛØ´ ÙØ³ØªÙد.
تعا٠٠با Ú©ÙØ³ÙÙ
ÙÙ Ø§ÙØ·Ùر ک٠٠ا رÙÛ DOM کار Ù ÛâÚ©ÙÛÙ Ø Ù Ù Ú©Ù Ø§Ø³Øª Ø¨Ø®ÙØ§ÙÛÙ Ø¬Ø§ÙØ§ اسکرÛپت را ÙÛØ² رÙÛ Ø¢Ù Ø§Ø¹Ù Ø§Ù Ú©ÙÛÙ . ٠اÙÙØ¯: ÛÚ© Ú¯Ø±Ù Ø¨Ú¯ÛØ±Ûد Ù Ú©Ø¯Û Ø±Ø§ Ø¨Ø±Ø§Û ØªØºÛÛØ± آ٠اجرا Ú©ÙÛØ¯ تا ÙØªÛج٠را ببÛÙÛØ¯. در اÛÙØ¬Ø§ ÚÙØ¯ ÙÚ©ØªÙ Ø¨Ø±Ø§Û Ø¬Ø§Ø¨Ø¬Ø§ÛÛ Ø¨Û٠زباÙÙ Elements Ù Ú©ÙØ³ÙÙ ÙØ¬Ùد دارد.
Ø¨Ø±Ø§Û Ø´Ø±ÙØ¹:
- اÙÙÛÙ
<li>را در زباÙÙ Elements Ø§ÙØªØ®Ø§Ø¨ Ú©ÙÛØ¯. - بزÙÛØ¯ Esc â Ú©ÙØ³Ù٠درست Ø²ÛØ± زباÙÙ Elements باز Ù Û Ø´ÙØ¯.
اکÙÙ٠آخرÛÙ Ø¹ÙØµØ± Ø§ÙØªØ®Ø§Ø¨ شد٠ب٠عÙÙØ§Ù 0$ در دسترس Ø§Ø³ØªØ Ø¹ÙØµØ± Ø§ÙØªØ®Ø§Ø¨ Ø´Ø¯Ù ÙØ¨ÙÛ 1$ Ù ØºÛØ±Ù است.
Ù
ا Ù
ÛâØªÙØ§ÙÛÙ
Ø¯Ø³ØªÙØ±Ø§Øª را رÙÛ Ø¢ÙÙØ§ اجرا Ú©ÙÛÙ
. ب٠عÙÙØ§Ù Ù
ثا٠$0.style.background = 'red'Ø Ø¢ÛØªÙ
Ù ÙÛØ³Øª Ø§ÙØªØ®Ø§Ø¨ شد٠را ÙØ±Ù
ز Ù
ÛâÚ©ÙØ¯Ø Ù
اÙÙØ¯ اÛÙ:
ب٠اÛÙ ØªØ±ØªÛØ¨ Ù ÛâØªÙØ§Ù ÛÚ© گر٠از Elements را در Ú©ÙØ³ÙÙ Ø¯Ø±ÛØ§Ùت کرد.
ÛÚ© را٠برگشت ÙÙ
ÙØ³Øª اگر Ù
ØªØºÛØ±Û ÙØ¬Ùد دارد ک٠ب٠ÛÚ© گر٠DOM ارجاع Ù
ÛâØ¯ÙØ¯Ø Ù
ÛâØªÙØ§ÙÛÙ
از Ø¯Ø³ØªÙØ± inspect(node) در Ú©ÙØ³ÙÙ Ø§Ø³ØªÙØ§Ø¯Ù Ú©ÙÛÙ
تا آ٠را در ÙØ³Ù
ت Elements ببÛÙÛÙ
.
ÛØ§ ÙÙØ· Ù
ÛâØªÙØ§ÙÛÙ
گر٠DOM را در Ú©ÙØ³ÙÙ Ø®Ø±ÙØ¬Û Ø¨Ú¯ÛØ±ÛÙ
Ù âØ¯Ø±Ø¬Ø§â Ú©Ø§ÙØ´ Ú©ÙÛÙ
Ø Ù
اÙÙØ¯ document.body در Ø²ÛØ±:
اÛÙ Ø§ÙØ¨ØªÙ Ø¨Ø±Ø§Û Ø§ÙØ¯Ø§Ù اشکاÙâØ²Ø¯Ø§ÛÛ Ø§Ø³Øª. از ÙØµÙ Ø¨Ø¹Ø¯Û Ø¨Ø§ Ø§Ø³ØªÙØ§Ø¯Ù از Ø¬Ø§ÙØ§Ø§Ø³Ú©Ø±Ûپت ب٠DOM Ø¯Ø³ØªØ±Ø³Û Ù¾ÛØ¯Ø§ Ù ÛâÚ©ÙÛ٠٠آ٠را Ø§ØµÙØ§Ø Ù ÛâÚ©ÙÛÙ .
Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù Ù Ø±ÙØ±Ú¯Ø± Ú©Ù Ú© Ø¨Ø²Ø±Ú¯Û Ø¯Ø± ØªÙØ³Ø¹Ù ÙØ³ØªÙد: ٠ا Ù ÛâØªÙØ§ÙÛÙ DOM را Ú©Ø§ÙØ´ Ú©ÙÛÙ Ø ÚÛØ²ÙاÛÛ Ø±Ø§ Ø§Ù ØªØØ§Ù Ú©ÙÛ٠٠ببÛÙÛÙ ÚÙ Ù Ø´Ú©ÙÛ Ù¾ÛØ´ Ù ÛâØ¢ÛØ¯.
Ø®ÙØ§ØµÙ
ÛÚ© Ø³ÙØ¯ HTML/XML Ø¯Ø§Ø®Ù Ù Ø±ÙØ±Ú¯Ø± ب٠عÙÙØ§Ù درخت DOM ÙØ´Ø§Ù داد٠٠ÛâØ´ÙØ¯.
- تگâÙØ§ ب٠گرÙâÙØ§Û Ø¹ÙØµØ± تبدÛÙ Ù ÛâØ´ÙÙØ¯ ٠ساختار را تشکÛÙ Ù ÛâØ¯ÙÙØ¯.
- ٠ت٠ب٠گرÙâÙØ§Û ٠تÙÛ ØªØ¨Ø¯ÛÙ Ù ÛâØ´ÙØ¯.
- â¦ Ù ØºÛØ±ÙØ ÙÙ Ù ÚÛØ² در HTML جاÛÚ¯Ø§Ù Ø®ÙØ¯ را در DOM Ø¯Ø§Ø±Ø¯Ø ØØªÛ Ú©Ø§Ù ÙØªâÙØ§.
٠ا Ù ÛâØªÙØ§ÙÛ٠از Ø§Ø¨Ø²Ø§Ø±ÙØ§Û ØªÙØ³Ø¹Ù دÙÙØ¯Ù Ø¨Ø±Ø§Û Ø¨Ø§Ø²Ø±Ø³Û (Inspect) DOM Ù Ø§ØµÙØ§Ø Ø¢Ù Ø¨Ù ØµÙØ±Øª Ø¯Ø³ØªÛ Ø§Ø³ØªÙØ§Ø¯Ù Ú©ÙÛÙ .
در اÛÙØ¬Ø§ ب٠اصÙ٠اÙÙÛÙØ پرکاربردترÛÙ Ù Ù ÙÙ âØªØ±ÛÙ Ø§ÙØ¯Ø§Ù ات Ø¨Ø±Ø§Û Ø´Ø±ÙØ¹ پرداختÛÙ . در https://developers.google.com/web/tools/chrome-devtools Ø§Ø³ÙØ§Ø¯ گستردÙâØ§Û Ø¯Ø± Ù ÙØ±Ø¯ Ø§Ø¨Ø²Ø§Ø±ÙØ§Û Ø¨Ø±ÙØ§Ù Ù ÙÙÛØ³ Chrome ÙØ¬Ùد دارد. Ø¨ÙØªØ±ÛÙ Ø±Ø§Ù Ø¨Ø±Ø§Û ÛØ§Ø¯Ú¯ÛØ±Û Ø§Ø¨Ø²Ø§Ø±ÙØ§ اÛ٠است ک٠آÙâÙØ§ Ø§Ù ØªØØ§Ù Ú©ÙÛØ¯Ø Ù ÙÙÙØ§ را Ø¨Ø®ÙØ§ÙÛØ¯: اکثر گزÛÙÙâÙØ§ ÙØ§Ø¶Ø ÙØ³ØªÙد. Ø¨Ø¹Ø¯Ø§ÙØ ÙÙØªÛ Ø¢ÙÙØ§ را Ø¨Ù Ø·ÙØ± Ú©ÙÛ Ø´ÙØ§Ø®ØªÛØ¯Ø Ø§Ø³ÙØ§Ø¯ را Ø¨Ø®ÙØ§ÙÛØ¯ ٠بÙÛ٠را Ø§ÙØªØ®Ø§Ø¨ Ú©ÙÛØ¯.
گرÙâÙØ§Û DOM Ø¯Ø§Ø±Ø§Û ÙÛÚÚ¯ÛâÙØ§ Ù Ø±ÙØ´âÙØ§ÛÛ ÙØ³ØªÙد ک٠ب٠٠ا ا٠کا٠٠ÛâØ¯ÙÙØ¯ بÛ٠آÙâÙØ§ Ù¾ÛÙ Ø§ÛØ´ Ú©ÙÛÙ Ø Ø¢ÙâÙØ§ را Ø§ØµÙØ§Ø Ú©ÙÛÙ Ø Ø¯Ø± ØµÙØÙ ØØ±Ú©Øª Ú©ÙÛÙ Ù Ù ÙØ§Ø±Ø¯ دÛگر. در ÙØµÙâÙØ§Û Ø¨Ø¹Ø¯Û Ø¨Ù Ø¢ÙâÙØ§ Ø®ÙØ§ÙÛ٠پرداخت.
ÙØ¸Ø±Ø§Øª
<code>Ø§Ø³ØªÙØ§Ø¯Ù Ú©ÙÛØ¯Ø Ø¨Ø±Ø§Û ÚÙØ¯Û٠خط â کد را درÙ٠تگ<pre>ÙØ±Ø§Ø± دÙÛØ¯Ø Ø¨Ø±Ø§Û Ø¨ÛØ´ از د٠خط کد â Ø§Ø² ÛÚ© جعبÙÙ Ø´ÙÛ Ø§Ø³ØªÙØ§Ø¯Ù Ú©ÙÛØ¯. (plnkrØ jsbinØ codepenâ¦)