JavaScript HTML DOM---遗漏知识再整理(向html添加/删除元素,改变内容和css)

时间:2021-08-29 05:29:16

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>

JavaScript HTML DOM---遗漏知识再整理(向html添加/删除元素,改变内容和css)

(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("消息在 onload 事件触发后弹出。");

}

</script>

</head>

<body onload="mymessage()"></body>

</html>

(3)onchange 事件

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

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

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

(4)onmouseover 和 onmouseout 事件

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

(5)onmousedown、onmouseup 以及 onclick 事件

onmousedown, onmouseup 以及 onclick 构成了鼠标点击事件的所有部分。首先当点击鼠标按钮时,会触发 onmousedown 事件,当释放鼠标按钮时,会触发 onmouseup 事件,最后,当完成鼠标点击时,会触发 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);