ภาษาไทย
<!DOCTYPE html สาธารณะ "-//W3C//DTD XHTML 1.0 การเปลี่ยนผ่าน//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http //www.w3.org/1999/xhtml" lang="zh" xml:lang="zh"> <head> <meta http-equiv="Content-Type" content="text/html; -8" /> <meta name="developer" content="Realazy" /> <title>บับเบิ้ลใน JavaScript DOM</title> <style type="text/css" media="screen"> div * {display: ปิดกั้น; ระยะขอบ:4px; ช่องว่างภายใน:4px; เส้นขอบ: 1px สีขาวทึบ;} พื้นที่ข้อความ {กว้าง: 20em; ความสูง:2em;} </style> <script type="text/javascript"> //<![CDATA[ function init(){ var log = document.getElementsByTagName('textarea')[0]; var ทั้งหมด = document.getElementsByTagName('div')[0].getElementsByTagName('*'); สำหรับ (var i = 0, n = all.length; i < n; ++i){ all[i].onmouseover = function(e){ this.style.border = '1px solid red'; log.value = '鼠标现在进入的是: ' + this.nodeName; - all[i].onmouseout = function(e){ this.style.border = '1px สีขาวทึบ'; - } var all2 = document.getElementsByTagName('div')[1].getElementsByTagName('*'); สำหรับ (var i = 0, n = all2.length; i < n; ++i){ all2[i].onmouseover = function(e){ this.style.border = '1px solid red'; ถ้า (e) // 停止事件冒泡 e.stopPropagation(); อย่างอื่น window.event.cancelBubble = จริง; log.value = '鼠标现在进入的是: ' + this.nodeName; - all2[i].onmouseout = function(e){ this.style.border = '1px สีขาวทึบ'; - } } window.onload = เริ่มต้น; //]]> </script> </head> <body> <h1>Bubble ใน JavaScript DOM</h1> <p>DOM 树的结构是:</p> <pre><code> UL - LI - A - SPAN </code></pre> <div> <ul> <li><a href="#"><span>Bubbllllllllllllllle</span></a></li> <li><a href ="#"><span>Bubbllllllllllllllle</span></a></li> </ul> </div> <textarea></textarea> <p>鼠标进入UL的任何一个子元素,如果不停止冒泡,我们从UL到SPAN都定义了鼠标悬停(<code>mouseover</code>)事件,这个事件会上升了UL,从而从鼠标所进入的元素到UL元素都会有红色的边。 </p> <div> <ul> <li><a href="#"><span>Bubbllllllllllllllle</span></a></li> <li><a href="#"><span >Bubbllllllllllllllle</span></a></li> </ul> </div> <p>如果停止冒泡,事件不会上升,我们就可以获取精确的鼠标进入元素。</p> < /ตัว> </html>