首页 > 代码库 > JavaScript HTML DOM---遗漏知识再整理

JavaScript HTML DOM---遗漏知识再整理

1.  HTML DOM 改变 HTML 内容;(HTML DOM 允许 JavaScript 改变 HTML 元素的内容。)

(1)改变 HTML 输出流

在 JavaScript 中,document.write() 可用于直接向 HTML 输出流写内容。

绝对不要在文档加载完成之后使用 document.write()。这会覆盖该文档。

<!DOCTYPE html><html><body><script>document.write(Date());</script></body></html>

技术分享

 

 

(2)改变 HTML 内容

修改 HTML 内容的最简单的方法时使用 innerHTML 属性。

(3)改变 HTML 属性

改变了 <img> 元素的 src 属性

<!DOCTYPE html><html><body><img id="image" src="smiley.gif"><script>document.getElementById("image").src="landscape.jpg";</script></body></html>

 

  1. 2.  HTML DOM 改变 CSS

改变 HTML 样式

改变 HTML 元素的样式,请使用这个语法

document.getElementById(id).style.property=new style

 

<!DOCTYPE html><html><body><h1 id="id1">My Heading 1</h1><button type="button" onclick="document.getElementById(‘id1‘).style.color=‘red‘">Click Me!</button></body></html>

 

改变了 id="id1" 的 HTML 元素的样式,当用户点击按钮时

3.   JavaScript HTML DOM 事件

HTML DOM 使 JavaScript 有能力对 HTML 事件做出反应。

HTML 事件的例子:

  • 当用户点击鼠标时
  • 当网页已加载时
  • 当图像已加载时
  • 当鼠标移动到元素上时
  • 当输入字段被改变时
  • 当提交 HTML 表单时
  • 当用户触发按键时

当用户在 <h1> 元素上点击时,会改变其内容:<!DOCTYPE html>

<html><body><h1 onclick="this.innerHTML=‘Ooops!‘">点击文本!</h1></body></html>

 

从事件处理器调用一个函数

<!DOCTYPE html><html><head><script>function changetext(id){id.innerHTML="Ooops!";}</script></head><body><h1 onclick="changetext(this)">Click on this text!</h1></body></html>

 

(1)  HTML 事件属性

即调用函数

(2)onload 和 onunload 事件

onload 和 onunload 事件会在用户进入或离开页面时被触发。

onload 事件可用于检测访问者的浏览器类型和浏览器版本,并基于这些信息来加载网页的正确版本。

onload 和 onunload 事件可用于处理 cookie。

Onload事件:

function mymessage(){      alert("消息在 onl oad 事件触发后弹出。");}</script></head> <body onload="mymessage()"></body> </html>

 

(3)onchange 事件

onchange 事件常结合对输入字段的验证来使用。

下面是一个如何使用 onchange 的例子。当用户改变输入字段的内容时,会调用 upperCase() 函数。

<input type="text" id="fname" onchange="upperCase()">

(4)onmouseover 和 onm ouseout 事件

onmouseover 和 onm ouseout 事件可用于在用户的鼠标移至 HTML 元素上方或移出元素时触发函数。

(5)onmousedown、onmouseup 以及 onclick 事件

onmousedown, onm ouseup 以及 onclick 构成了鼠标点击事件的所有部分。首先当点击鼠标按钮时,会触发 onm ousedown 事件,当释放鼠标按钮时,会触发 onm ouseup 事件,最后,当完成鼠标点击时,会触发 onclick 事件。

6)获取焦点时focus事件

<script>

function myFunction(x){

       x.style.background="yellow";

}

</script>

</head>

<body>

 

输入你的名字: <input type="text" onfocus="myFunction(this)">

<p>当输入框获取焦点时,修改背景色(background-color属性)将被触发。</p>

 

</body>

</html>

 

 

输入你的名字

<input type="text" onfocus="myFunction(this)"><p>当输入框获取焦点时,修改背景色(background-color属性)将被触发。</p> </body></html>

 

 

4.   JavaScript HTML DOM EventListener

添加监听事件:当用户点击按钮时触发监听事件

document.getElementById("myBtn").addEventListener("click", displayDate);

 

第一个参数是事件的类型 (如 "click" 或 "mousedown").

第二个参数是事件触发后调用的函数。

第三个参数是个布尔值用于描述事件是冒泡还是捕获。该参数是可选的。

注意:不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。

(1)向同一个div元素中添加多个事件句柄

element.addEventListener("mouseover", myFunction);element.addEventListener("click", mySecondFunction);element.addEventListener("mouseout", myThirdFunction);

 

(2) 向 Window 对象添加事件句柄

当用户重置窗口大小时添加事件监听:

window.addEventListener("resize", function(){    document.getElementById("demo").innerHTML = sometext;});

 

5.   HTML DOM 元素

(1) JavaScript HTML DOM 元素(节点),即创建新的html元素

如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素。

<div id="div1"><p id="p1">This is a paragraph.</p><p id="p2">This is another paragraph.</p></div><script>var para=document.createElement("p");var node=document.createTextNode("This is new.");para.appendChild(node);var element=document.getElementById("div1");element.appendChild(para);</script>

 

这段代码创建新的<p> 元素:

var para=document.createElement("p");

 

如需向 <p> 元素添加文本,您必须首先创建文本节点。这段代码创建了一个文本节点:

var node=document.createTextNode("This is a new paragraph.");

 

然后您必须向 <p> 元素追加这个文本节点:

para.appendChild(node);

 

最后您必须向一个已有的元素追加这个新元素。

这段代码找到一个已有的元素:

var element=document.getElementById("div1");

 

以下代码在已存在的元素后添加新元素:

element.appendChild(para);

 

(2) 删除已经有的html元素

<div id="div1"><p id="p1">This is a paragraph.</p><p id="p2">This is another paragraph.</p></div><script>var parent=document.getElementById("div1");var child=document.getElementById("p1");parent.removeChild(child);</script>

 

这个 HTML 文档含有拥有两个子节点(两个 <p> 元素)的 <div> 元素:

<div id="div1"><p id="p1">This is a paragraph.</p><p id="p2">This is another paragraph.</p></div>

 

找到 id="div1" 的元素:

var parent=document.getElementById("div1");

 

找到 id="p1" 的 <p> 元素:

var child=document.getElementById("p1");

 

从父元素中删除子元素:

parent.removeChild(child);

 

JavaScript HTML DOM---遗漏知识再整理