JavaScript-05 DOM编程 全网最最 详细最全面最易懂的

简介: JavaScript-05 DOM编程 全网最最 详细最全面最易懂的

一.DOM基本介绍

1.1 什么是DOM  

文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标记语言

HTMLXML)的标准编程接口

W3C已经定义了一系列的DOM接口,通过这些DOM接口可以改变网页的内容、结构和样式。

1.2 DOM树(家族谱)

当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model),HTML DOM 模型

被结构化为对象树:

HTML DOM是HTML的标准对象模型和编程接口。其定义了:

  • 作为对象的HTML元素
  • 所有HTML元素的属性
  • 访问所有的HTML元素的方法
  • 所有HTML元素的事件

文档:一个页面就是一个文档,DOM中使用document表示

元素:页面中所有的标签都是元素,DOM中使用 element 表示

节点:网页中所有的内容都是节点(标签,属性,文本,注释等),DOM中用 node 表示

注意:DOM把以上内容都看作为对象

二.基本属性与方法

2.1  属性

  • nodeName:   返回节点的名称,依据其类型。
  • nodeType:    返回节点的类型
  • attributes:     返回元素的属性。
  • childNodes:   返回元素的子节点的 NodeList。
  • firstChild:      返回元素的首个子节点
  • lastChild:      返回元素的最后一个子节点。
  • parentNode: 返回元素的父节点
  • nextSibling:  返回元素之后紧跟的节点。
  • previousSibling:返回元素之前紧随的节点。
  • textContent:   设置或返回元素及其后代的文本内容
  • innerTest:       设置或返回元素后代的文本内容
  • innerHTML:    设置或返回元素后代的内容

2.2 方法

  • hasAttribute(name):返回元素是否拥有指定的属性
  • hasAttributes():返回元素是否拥有属性。
  • hasChildNodes():返回元素是否拥有子节点
  • createAttribute(node):创建属性节点
  • createElement(node):创建元素节点。
  • createTextNode(node):创建文本节点。
  • appendChild(node):向节点的子节点列表末尾添加新的子节点
  • cloneNode(include_all:true,false):克隆节点。
  • removeAttribute(name):删除指定的属性。
  • removeChild(node):删除子节点
  • replaceNode(newNode):替换节点。[仅IE]
  • replaceChild(newNode, oldNode):替换子节点。
  • getElementById(id):找到具有指定id的子孙元素。[HTML DOM]
  • getElementsByName(name):找到具有指定name的子孙元素。[HTML DOM]
  • getElementsByTagName(name):找到具有指定标签名的子孙元素。
  • getAttribute(name):返回属性的值。
  • setAttribute():添加新属性

三.查找HTML DOM元素

HTML DOM能够通过JavaScript进行访问(也可以通过其他编程语言)。在DOM 中,所有HTML元素都被定义为对象。我们可以通过JavaScript 对这些对象操作,改变HTML元素的内容。

2.1 getElementById()

使用getElementByID()方法可以获得带ID的元素对象

<div id="oDiv">今天你真棒!</div>
<script type="text/javascript">
var oDiv = document.getElementById('oDiv');
console.log(oDiv)
</script>

2.2. getElementsByTagName()

使用getElementsByTagName()方法可以返回带有指定标签名的对象集合。

document.getElementsByTagName('标签名')

注意事项:

  • 因为得到的是一个对象的集合,所以想要操作里面的元素 就需要遍历
  • 得到元素对象是动态

还可以获取某个元素(父元素)内部的所有指定标签的子元素。

element.getElementsByTagName('标签名');

注意:父元素必须是单个对象(必须指明是哪一个元素的对象)。获取的时候不包括父元素自己。

2.3  getElementsByClassName()

getElementsByName() 方法可返回带有指定名称的对象的集合。

该方法与 getElementById() 方法相似,但是它查询元素的 name 属性,而不是 id 属性。

另外,因为一个文档中的 name 属性可能不唯一(如 HTML 表单中的单选按钮通常具有相同的 name

性),所有 getElementsByName() 方法返回的是元素的数组,而不是一个元素。

演示示例:

function s_input(){
  var aInput=document.getElementsByName("season");
  var sStr="";
  for(var i=0;i<aInput.length;i++){
  sStr+=aInput[i].value+"<br />";
  }
document.getElementById("s").innerHTML=sStr;
}

  四 .改变HTML元素(内容)

 方法

描述
element.innerHTML=new HTML content 改变元素的HTML内容
element.innerTEXT = new text 改变元素的文本内容
element.attribute = new value 改变 HTML 元素的属性值
element.setAttribute(attribute, value) 改变 HTML 元素的属性值
element.hasAttribute(attribute) 判断元素是否有该属性
element.removeAttribute(attribute) 删除元素属性
element.style.property = new style 改变 HTML 元素的样式

五. DOM节点操作介绍

5.1 节点概述

  • 网页中的所有内容都是节点(标签、属性、文本、注释等等),在DOM中,节点使用Node来表示。
  • HTML DOM树中的所有节点均可通过JavaScript进行访问,所有HTML元素(节点)均可被修改,也可以创建或删除。

一般的,节点至少拥有nodeType(节点类型)、nodeName(节点名称)和nodeValue(节点值)这三个基本属性

  • 元素节点 nodeType为1
  • 属性节点nodeType为2
  • 文本节点nodeType为3(文本节点包含文字、空格、换行等)

【总结】我们在实际开发中,节点操作主要操作的是"元素节点"。

5.2节点的作用

获取页面元素。

  • 利用DOM提供的方法获取元素
  • document.getElementById()
  • document.getElementsByTagName()
  • document.querSelector等
  • 逻辑性不强、繁琐
  • 利用节点层级关系获取元素
  • 利用父子兄弟节点关系获取元素
  • 逻辑性强,但兼容性差

5.3 节点层级

5.3.1 父级节点 【node.parentNode】

利用DOM树可以把节点划分为不同的层级关系,常见的是父子兄层级关系

  • parentNode属性可返回某节点的父节点,注意是最近的一个父节点
  • 如果指定的节点没有父节点则返回null

5.3.2 子节点【parentNode.childNodes (标准)】

parentNode.childNodes返回包括指定节点的子节点的集合,该集合为即时更新的集合

注意:返回值里面包括了所有的子节点,包括元素节点,文本节点等。

如果想到获得里面的元素节点,则需要专门处理,所以我们一般不提倡使用childNodes

var ul = document.querySelector('ul');
for(var i = 0; i < ul.childNodes.lenth; i++) {
    if(ul.childNodes[i].nodeType == 1) {
    //ul.childNodes[i] 是元素节点
    console.log(ul.childNodes[i]);
    }
  }

5.3.3  兄弟节点

node.nextSibling

nextSibling返回当前元素的下一个兄弟节点,找不到则返回null,同样,也是包括所有节点

node.previousSibling

previousSiblin返回当前元素的上一个兄弟节点,找不到则返回null,同样,也是包括所有节点

特指元素节点

node.nextElementSibling

nextElementSibling返回当前元素下一个兄弟元素节点,找不到则返回null

node.previousElementSibling

previousElementSibling返回当前元素上一个兄弟节点找不到就返回null

5.4 节点操作

5.4.1 创建节点

document.createElement(‘tagName’)

document.createElement()方法创建由tagName指定的HTML元素。因为这些元素原先不存在是根据我们的需求动态生成的,所有我们也称为动态创建元素节点

5.4.2 添加节点

node.appendChild(child)

node.appendChild() 方法将一个节点添加到指定父节点的子节点列表末尾。类似于css里面的after伪元素

// 2.添加节点 node.appendChild(child)  node 父级  child子级
// 后面追加元素,类似数组中的push
var ul = document.querySelector('ul');
ul.appendChild(li);
// 3.添加节点  node.insertBefore(child,指定元素);
var lili = document.createElement('li');
ul.insertBefore(lili,ul.children[0]);

5.4.3 删除节点

node.removeCjild(child)

node.removeChild() 方法从DOM中删除一个子节点,返回删除的节点

// 1.获取元素
var ul = document.querySelector('ul');
// 2.删除元素  node.removeChild(child);
ul.removeChild(ul.children[0]);

5.4.4 复制节点(克隆节点)

node.cloneNode()

node.cloneNode() 方法返回调用该方法的节点的一个副本。也称为克隆节点/拷贝节点

注意:

  • 如果括号参数为空或者为false,则是浅拷贝,即只是克隆复制节点本身,不克隆里面的子节点
  • 如果括号参数为true,则是深度拷贝,会复制节点本身以及里面所有的子节点

node.cloneNode(); //浅拷贝,不复制内容,只复制标签
node.cloneNode(true); //深拷贝,复制内容、复制标签

六.案例


图片切换

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>图片切换</title>
    <script type="text/javascript">
      //数组的方式定义  保存所有的图片的名称
      var images = [
        "img/1.jpg",
        "img/2.jpg",
        "img/3.jpg",
        "img/4.jpg",
        "img/5.jpg"];
      var index = 0;
      //声明一个变量保存定时器
      var timer = null;
      //加载函数
      window.onload = function(){
        //获取图片标签   调用src重新赋值
        var oImg = document.querySelector("img");
        //封装一个函数 保存下一张的代码
        function next(){
          index++;
          if(index >= images.length){
            index = 0;//归0
          }
          oImg.src = images[index];//0 1 2 3 4
          console.log(index);
        }
        //手动点击下一张  进行切换
        var nextBtn = document.getElementById("nextBtn");
        //设置点击事件
        nextBtn.onclick = function(){
          next();
        };
        //手动点击上一张  进行切换
        var backBtn = document.getElementById("backBtn");
        //设置点击事件
        backBtn.onclick = function(){
          index--;
          if(index < 0){
            index = images.length-1;//归0
          }
          oImg.src = images[index];//0 1 2 3 4
          console.log(index);
        };
        //自动切换的按钮
        var autoBtn = document.getElementById("autoBtn");
        autoBtn.onclick = function(){
          window.clearInterval(timer);
          //设置定时器
          timer = window.setInterval(function(){
            next();
          },2000);
        };
        var closeBtn = document.getElementById("closeBtn");
        closeBtn.onclick = function(){
          window.clearInterval(timer);
        }
      };
    </script>
  </head>
  <body>
    <!-- 调用src属性   对象.属性 -->
    <img src="img/1.jpg" alt="" width="300" height="300">
    <hr>
    <button id = "backBtn">上一张</button>
    <button id="nextBtn">下一张</button>
    <button id="autoBtn">自动切换图片</button>
    <button id="closeBtn">关闭切换图片</button>
  </body>
</html>
相关文章
|
3月前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
|
4月前
|
存储 JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果+1
JavaScript编程实现tab选项卡切换的效果+1
|
2月前
|
JavaScript 前端开发 索引
js中DOM的基础方法
【10月更文挑战第31天】这些DOM基础方法是操作网页文档结构和实现交互效果的重要工具,通过它们可以动态地改变页面的内容、样式和行为,为用户提供丰富的交互体验。
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
54 5
|
2月前
|
前端开发 JavaScript 持续交付
提高JavaScript编程效率
提高JavaScript编程效率
31 3
|
2月前
|
JavaScript 前端开发 开发者
.js的dom元素操作
【10月更文挑战第29天】通过灵活运用这些 DOM 元素操作方法,JavaScript 可以实现丰富的网页交互效果,如动态更新页面内容、响应用户操作、创建和删除页面元素等。在实际开发中,开发者可以根据具体的需求和场景,选择合适的 DOM 元素操作方法来实现所需的功能,为用户提供更加流畅和动态的网页体验。
|
2月前
|
自然语言处理 JavaScript 前端开发
JavaScript闭包:解锁编程潜能,释放你的创造力
【10月更文挑战第25天】本文深入探讨了JavaScript中的闭包,包括其基本概念、创建方法和实践应用。闭包允许函数访问其定义时的作用域链,常用于数据封装、函数柯里化和模块化编程。文章还提供了闭包的最佳实践,帮助读者更好地理解和使用这一强大特性。
24 2
|
3月前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
91 4
|
4月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 节点列表
JavaScript HTML DOM 节点列表
26 5
|
4月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 集合(Collection)
JavaScript HTML DOM 集合(Collection)
43 4