首页 > 其他分享 >三、DOM获取

三、DOM获取

时间:2024-11-07 18:44:28浏览次数:3  
标签:DOM 元素 获取 3.2 var document 节点

3.1、DOM初相识

3.1.1、DOM简介

文档对象模型(Document Object Model ,简称DOM),它就是一些系列编程接口,有了这些接口,就可以改变页面内容,结构和样式

DOM树:

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

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

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

DOM把以上内容都看作是对象

3.1.2、事件前言

事件,就是用户和浏览器之间的交互行为,比如:点击按钮,鼠标移动,关闭窗口.....

事件非常多,为了方便演示,先学简单的事件,后面再详细学习

方式一、

标签中对应的属性(事件属性)中设置一些js代码,这样当事件被触发时,这些代码将会被执行

这种方式:结构与行为耦合,不方便维护,不推荐使用

<button id="btn"  onclick="alert('哈喽');">我是一个按钮</button> //onclick点击事件,点击的时候触发

方式二、

可以为按钮的对应事件绑定处理函数的形式来响应事件,这样当事件被触发时,其对应的函数将会被调用

<body>
    <button id="btn">我是一个按钮</button>
    <script>
      //第一步:获取按钮对象
      var btn=document.getElementById("btn");
      //第二步:绑定一个单击事件
      //像这种为单击事件绑定的函数,我们称为单击响应函数
      btn.onclick=function(){
          alert("你好")
      }
    </script>    
</body>

3.1.3、文档的加载

浏览器在加载一个页面时,是按照自上向下的顺序加载的,读取到一行就运行一行,如果将script标签写到页面的上边, 在代码执行时,页面还没有加载,页面没有加载DOM对象也没有加载 ,会导致无法获取到DOM对象。

第一种加载情况:

将js代码编写到页面的下部就是为了,可以在页面加载完毕以后再执行js代码

<button id="btn">点我一下</button>
  <script type="text/javascript">
    //获取id为btn的按钮
    var btn = document.getElementById("btn");
    //为按钮绑定一个单击响应函数
    btn.onclick = function () {
      alert("hello");
    };
  </script>

第二种加载写法:

onload事件会在整个页面加载完成之后才触发, 为window绑定一个onload事件 ,该事件对应的响应函数将会在页面加载完成之后执行, 这样可以确保我们的代码执行时所有的DOM对象已经加载完毕了

window.onload = function () {
    //获取id为btn的按钮
    var btn = document.getElementById("btn");
    //为按钮绑定一个单击响应函数
    btn.onclick = function () {
      alert("hello");
    };
  };

3.2、DOM获取

DOM在我们实际开发中主要用来操作元素。一般有以下方法获取DOM

3.2.1、getElementById()

通过id属性获取一个元素节点对象,参数:id是大小写敏感的字符串,返回的是一个元素对象

补充1:innerHTML 可读写,一方面可获取到元素内部的html代码,另一方面可以操作更改元素内容,包括标签,保留空格和换行,比较常用

补充2:innerText 可读写,它和innerHTMl类似,不同的是更改元素内容的时候,它会自动将html标签,空格和换行去除

补充3:console.dir 打印我们返回的元素对象,更好的查看里面的属性和方法

var btn01 = document.getElementById("btn01");   //查找#btn01节点
  btn01.onclick = function () {
    var bj = document.getElementById("bj") //查找#bj节点
    alert(bj.innerHTML);
    //console.dir(bj, "bj");
  };

3.2.2、getElementsByTagName()

3.2.2.1、根据标签名来获取一组元素节点对象

返回一个类数组(伪数组)对象,所有查询到的元素都会封装到对象中,即使查询到的元素只有一个,也会封装到伪数组中返回;如果页面中没有这个元素,则会返回一个空的伪数组;

var btn02 = document.getElementById("btn02");
    btn02.onclick = function () {
      var lis = document.getElementsByTagName("li");
      //打印lis
      //alert(lis.length);
      //遍历lis
      for (var i = 0; i < lis.length; i++) {
        console.log(lis[i].innerHTML);
      }
    };
3.2.2.2、获取某个元素(父元素)内部所有指定标签名的元素
element.getElementsByTagName('标签名')

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

//获取id为city的元素
var city = document.getElementById("city");
/*  1:city.getElementsByTagName(); 获取元素下的一组节点  */
var lis = city.getElementsByTagName("li");

3.2.3、getElementsByName()

通过name属性获取一组元素节点对象

补充2: innerHTML用于获取元素内部的HTML内容的,对于自结束标签,这个属性没有意义

补充3:如果需要读取元素节点属性,语法: 元素.属性名,

例如:元素.id ;元素.name ;元素.src ;元素.href等

表单属性:type、value、checked、selected、disabled等

注意:class属性不能采用这种方式,读取class属性时需要使用 元素.className

value值:就是输入文本框中的内容,要修改value值 element.value = "~~";

var btn03 = document.getElementById("btn03");
  btn03.onclick = function () {
    var inputs = document.getElementsByName("gender");
    //alert(inputs.length);
    for (var i = 0; i < inputs.length; i++) {
       //alert(inputs[i].innerHTML);
      // alert(inputs[i].value);
      alert(inputs[i].className);
    }
  };

3.2.4、getElementsByClassName()

通过class属性获取一组元素节点对象 (不支持IE8及以下浏览器)

var btn04 = document.getElementById("btn04");
  btn04.onclick = function () {
    var classs = document.getElementsByClassName("inner");
    for (var i = 0; i < classs.length; i++) {
      alert(classs[i].className);
    }
  };

3.2.5、childNodes、children

返回父元素下的所有子节点

(1)、childNodes属性会获取包括文本节点在内的所有节点,DOM标准,标签间的空白也会被当成文本节点

(2)、children属性可以获取当前元素的所有子元素,不包括空白文档了

3.2.6、firstChild、firstElementChild

返回父元素下的第一个子节点

(1)、firstChild 第一个子节点(包括空白的文本节点)

(2)、firstElementChild 获取当前元素的第一个子元素

3.2.7、返回某元素的父节点

语法:某元素.parentNode

3.2.8、返回某元素的前/后一个兄弟节点

(1)、 previousSibling [ˈpriːviəs] ['sibliŋ] 返回前一个兄弟节点 也有可能获取到空白的文本

(2)、 previousElementSibling 返回前一个兄弟元素,不包括空白文本,注意:不支持ie8及以下的浏览器

(3)、 nextSibling返回下一个兄弟节点 也有可能获取到空白的文本

(4)、 nextElementSibling 返回下一个兄弟元素,不包括空白文本,注意:不支持ie8及以下的浏览器

var div = document.querySelector(".box1 div")
var div = document.querySelector(".box1")
var div=document.querySelectorAll(".box1")

3.2.9、获取body标签

//方法一
var body=document.getElementsByTagName("body")[0];
//方法二
var body = document.body

3.2.10、获取html根标签

var html = document.documentElement;

3.2.11、获取页面中所有的元素

 //第一种方式
var all=document.all;
//第二种方式
var all = document.getElementsByTagName("*")

3.2.12、document.querySelector()

-需要一个选择器的字符串作为参数,可以根据一个css选择器来查询 一个元素节点对象

-该方法总会返回唯一的元素,如果满足条件的元素是多个,那么它只会返回第一个

-IE8以上的都适用

3.2.13、document.querySelectorAll()

-该方法和qureySelector()用法类似,不同的是它将会将符合条件的所有元素封装到一个伪数组中返回

-即使符合条件的元素只有一个,它也会返回数组

var div = document.querySelector(".box1 div")
var div = document.querySelector(".box1")
var div=document.querySelectorAll(".box1")

标签:DOM,元素,获取,3.2,var,document,节点
From: https://blog.csdn.net/Aming_888/article/details/143605261

相关文章

  • React-Router-Dom6 最佳实践
    React-Router-Dom6最佳实践一咻世界都变了​关注 6人赞同了该文章​展开目录 react-router-dom6使用之前只使用过一次react-router,目前官方从5开始就已经放弃了原有的react-router库,统一命名为 react-router-dom了实现......
  • 使用 Let’s Encrypt 获取免费SSL证书
    文章目录前言申请需求详细步骤:安装Certbot使用DNS验证生成证书找到生成的证书文件将证书文件复制到目标服务器在目标服务器上配置Nginx使用证书注意更新证书本地操作实例总结前言之前不太了解SSL免费证书,只研究过一点自签名SSL证书的知识,前几年的12306就是用的......
  • Vue3 - 详细实现虚拟列表前端虚拟滚动列表解决方案,vue3长列表优化之虚拟列表,解决列表
    前言Vue2版本,请访问这篇文章在vue3项目开发中,详解实现虚拟列表高度不固定(不定高)且复杂含有图片视频等复杂虚拟列表教程,决列表每项高度不确定及img图像或视频的加载方案,利用缓冲区技术解决用户浏览时渲染不及时列表闪烁白屏/列表加载闪屏,解vue3实现虚拟列表优化大......
  • 鸿蒙开发进阶(HarmonyOS )通过 ArkTS 接口获取并访问公共目录
     鸿蒙NEXT开发实战往期必看文章:一分钟了解”纯血版!鸿蒙HarmonyOSNext应用开发!“非常详细的”鸿蒙HarmonyOSNext应用开发学习路线!(从零基础入门到精通)HarmonyOSNEXT应用开发案例实践总结合(持续更新......)HarmonyOSNEXT应用开发性能优化实践总结(持续更新......)通过Ar......
  • 基于开源 AI 智能名片、S2B2C 商城小程序的用户获取成本优化分析
    摘要:本文围绕用户获取成本(CAC)这一关键指标展开深入剖析,详细阐述其计算方式,并紧密结合开源AI智能名片与S2B2C商城小程序的独特性质,从多个维度探讨如何通过挖掘新的获客渠道、巧妙运用私域流量池等手段降低CAC,进而提升企业在竞争激烈的市场环境中的核心竞争力,为企业的可持续......
  • SpringBoot推荐图书阅读系统6c613 带论文文档1万字以上,文末可获取,
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统内容;用户,图书分类,图书信息开题报告内容一、课题背景与意义随着信息时代的到来,图书馆和在线阅读平台的书籍数量急剧增加,用户在寻找适合自己的阅读材料时......
  • SpringBoot图书馆借阅管理系统49zr9 本系统(程序+源码+数据库+调试部署+开发环境)带论文
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统内容:读者,图书分类,图书信息,图书借阅,图书归还,图书主题,出版时间,出版社分布,图书统计开题报告内容一、研究背景与意义随着信息技术的快速发展,图书馆作......
  • SpringBoot图片创作分享平台的设计与实现7l7cf 文末可获取,系统界面在最后面。
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统内容:用户,图片橱窗开题报告内容一、选题理由随着互联网技术的飞速发展和社交媒体的普及,图片已成为人们日常交流和分享的重要载体。然而,当前市场上的图片分......
  • winring0.sys 是一个系统驱动程序文件,它通常与第三方工具或软件一起使用,主要用于访问
    winring0.sys是一个系统驱动程序文件,它通常与第三方工具或软件一起使用,主要用于访问系统硬件信息和提供低级别硬件控制。这些工具或软件可能需要与操作系统的内核进行交互,或者获取系统的底层信息,而winring0.sys驱动程序就起到了桥梁的作用,允许这些程序进行底层硬件操作。下面是......
  • 使用python编写一个获取token的接口
    importrequestsfromrequests.authimportHTTPBasicAuthdefget_token():"""获取token的逻辑"""url="https://devxxxxxxxxtion/v2/token"#替换为实际的token获取URLclient_id="hAixxxeMPNxxxxGjF......