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


    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("消息在 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);
  • 相关阅读:
    TCP/IP和HTTP的举例理解
    c#中栈和堆的理解
    c#设计模式之单例模式
    JSON.stringify实例应用—将对象转换成JSON类型进行AJAX异步传值
    JSON.stringify初识
    c# 过滤字符串中的重复字符
    C#中jQuery Ajax实例(二)
    C#中jQuery Ajax实例(一)
    jQuery动态对表格Table进行添加或删除行以及修改列值操作
    asp.net中控件的Attributes用法
  • 原文地址:https://www.cnblogs.com/xingyue1988/p/6105956.html
Copyright © 2020-2023  润新知