学习总结之初识DOM篇(1)—— 获取节点元素

10 篇文章 2 订阅

本节内容

  • 简单的认识一下DOM是什么
  • JavaScript中非常重要的三种对象类型
  • 获取DOM元素的方法及存在的兼容性问题
  • 娱乐封装获取元素方法的集成函数

一、初识DOM

DOM:Document Object Model 文档对象模型

 DOM是一个对象,同时是一个宿主对象,是由浏览器提供的一个能够操作文档结构的对象。

DOM存在的目的

  1. DOM是浏览器提供的一系列操作HTML和XML方法的对象,使得JavaScript可以对页面的文档结构进行操作修改。
  2. DOM本身是无法直接操作CSS样式表的,但是添加内联样式修改元素样式

二、JavaScript中的三种对象(重要)

由ECMAScript提供的对象

本地对象『Native Object』

Object Boolean Number Array Function
Error TypeError SyntaxError RangeError ReferenecError TypeError URIError
Date RegExp

内置对象 『Build-In Object』

由ECMAScript提供的对象

Global 全局对象的全称
全局方法 -> isNaN parseInt parseFloat ...
全局属性 -> undefined NaN Infinity
数学对象 -> Math

宿主对象 『Host object』

由浏览器提供的对象

执行JS脚本的环境提供的对象/浏览器对象 -> 存在兼容性问题
不同浏览器提供的相同方法的实现方式可能不一样,因此会存在方法、属性的兼容性问题

浏览器对象 -> BOM和DOM对象
DOM对象其实是BOM对象中的一部分,但DOM对象是在W3C规范中具有定义的

三、获取元素的方法

根据元素标签获取元素:getElementsByTagName

  getElementsByTagName这个方法存在于两个原型对象上:① Document.prototype文档对象的原型对象上 ② HTMLElement.prototypeHTML元素对象的原型对象上。
 元素对象(如HTMLDivElement)的原型对象继承于HTMLElement对象,因此元素对象可以使用到HTMLElement.prototype上的方法,同理document的原型对象为HTMLDocument对象,继承于Document.prototype对象。
 getElementsByTagName返回的结果是一个元素集合HTMLCollection,查找到是调用此方法的元素下所有匹配标签的元素。
getElementsByTagName

根据元素类名获取元素:getElementsByClassName

 与getElementsByTagName类似,不再重复,我们直接来说用法:getElementsByClassName是获取到调用该方法元素下的所有匹配类名的元素集合。注意:在IE8及以下版本是没有getElementsByClassName这个方法的,因此getElementsByClassName方法是存在兼容性问题的。
getElementsByClassName

根据name属性与id属性获取元素:getElementById与getElementsByName

 两者与上述提到的类名、标签选择元素不同的是:这两个方式是只属于文档对象的方法,元素是无法使用这两个方法的。同时本节的getElementById元素获取方法返回的是单独的一个元素,而非元素集合。当页面上出现相同id的元素时,获取到的是其中的第一个元素。而getElementsByName返回的元素不再是元素集合,而是节点集合NodeList,不过此方法非常不实用,了解即可。
 注意:getElementById也是有兼容性问题的:在IE8及以下的浏览器不区分id的大小写、在IE8以下的浏览器中使用getElementById可以获取到name属性等于匹配值的元素
getElementById+getElementsByName

query系列之:querySelector与querySelectorAll

 这两种方法大家想必使用的也比较多,因为写起来比较短一些,且拼写难度也比上述的方法简单。query系列方法实际上比getElementsByClassName更早出现,也就是说这两个方法的兼容性比getElementsByClassName更好,但是他是在HTML5才引入的WebApi,两个方法使用的方式很类似,传入类似CSS选择器的参数来获取元素,querySelector是获取第一个匹配到的元素,querySelectorAll获取的是所有匹配的元素。
 注意:query系列存在两个缺陷:①性能差于其他选择元素的方法 ②不实时,存在缓存。性能弱于其他方法这个缺点在现在高性能计算机面前已经可以忽略了。真正意义上的缺陷是第二个不实时的问题。
query系列

四、简单封装获取元素的通用函数

 如果觉得document.getElementsByClassName或是document.getElementsByTagName写起来繁琐,也可以封装一个集成的获取元素的函数方法。可以模仿jQuery和querySelector的形式,传入一个类似css选择器的参数名,根据第一个字符来判断所要获取的元素信息。
 不过讲实话,这个封装的集成函数并不实用,仅供参考。
获取元素集成

五、总结

 我认为DOM属于JavaScript中非常重要也比较难学的部分,也不是说难掌握,主要是知识点太多了,比如页面的各种尺寸属性以及其兼容性问题、兼容性写法,事件类型、事件绑定的兼容性等等,高级的内容如用户鼠标行为预测、高效的元素替换方法模板替换等。因此我认为有必要将DOM学到的知识内容进行一次复习,且通过文章的方式进行记录,也通过自己举例子、讲解给读者或笔者自己听来提高对DOM这一块知识的掌握度。
 感谢您阅读到这,我是Donp1,下次见🐻‍❄️。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Spark是一种大数据处理的框架,它可以处理大量的数据并进行分析。初学者可以通过学习Spark的基本概念和使用方法,了解Spark的工作原理和应用场景。在学习Spark的过程中,需要掌握Spark的核心组件和API,例如Spark Core、Spark SQL、Spark Streaming等。此外,还需要学习Spark的部署和调优,以及与其他大数据技术的集成。 ### 回答2: Spark是一种基于内存的分布式计算框架,是大数据处理中最流行的技术之一。Spark简单易用,能够快速地处理海量数据,尤其是在机器学习和数据挖掘领域中表现突出。本文将从初识Spark的角度入手,介绍Spark的基本概念和使用。 一、Spark的基本概念 1. RDD RDD全称为Resilient Distributed Datasets,中文意思是弹性分布式数据集,它是Spark的核心数据结构。RDD是一个不可变的分布式的对象集合,可以跨越多个节点进行并行处理。一个RDD可以分为多个分区,每个分区可以在不同的节点上存储。 2. DAG DAG即Directed Acyclic Graph(有向无环图),它是Spark中的一个概念,用来表示作业的依赖关系。Spark将一个作业拆分成一系列具有依赖关系的任务,每个任务之间的依赖形成了DAG。 3. 窄依赖和宽依赖 对于一个RDD,如果一个子RDD的每个分区只依赖于父RDD的一个分区,这种依赖就称为窄依赖。如果一个子RDD的每个分区依赖于父RDD的多个分区,这种依赖就称为宽依赖。宽依赖会影响Spark的性能,应尽量避免。 二、Spark的使用 1. 安装Spark 要使用Spark,首先需要在本地或者集群上安装Spark。下载安装包解压缩即可,然后设置环境变量,即可在命令行中运行Spark。 2. Spark Shell Spark Shell是Spark的交互式命令行界面,类似于Python的交互式控制台,可以快速测试Spark代码。在命令行中输入spark-shell即可进入。 3. Spark应用程序 除了Spark Shell,Spark还支持以应用程序的形式运行。要创建一个Spark应用程序,可以使用Scala、Java、Python等语言进行编写。使用Spark API,读取数据、处理数据、保存数据等操作都可以通过编写代码完成。 总之,Spark是一种优秀的分布式计算框架,能够在海量数据处理中发挥出强大的作用。初学者可以从掌握RDD、DAG、依赖关系等基本概念开始,逐步深入学习Spark的使用。 ### 回答3: Spark是一种快速、分布式数据处理框架,它能够在成千上万个计算节点之间分配数据和计算任务。Spark的优势在于它支持多种语言和数据源,可以在内存中快速存储和处理数据。 在初学Spark时,我们需要对Spark的架构和核心组件有一些了解。首先,Spark的核心组件是Spark Core,它是一个可以用于建立各种应用程序的计算引擎。与此同时,Spark持有丰富的库,包括Spark SQL、Spark Streaming、MLLib和GraphX等,以支持在各种数据类型(文本、图像、视频、地理定位数据等)上运行各种算法。 若想要在Spark中进行任务,有两种编程API可供选择:Spark的核心API和Spark的SQL及DataFrame API。Spark的核心API基于RDDs(弹性分布式数据集),它是不可变的分布式对象集合,Spark使用RDD来处理、缓存和共享数据。此外,Spark的SQL及DataFrame API提供了更高层次的语言,可以处理结构化和半结构化数据。 除了组件和API之外,我们还需要了解Spark的4个运行模式:本地模式、Standalone模式、YARN模式和Mesos模式。本地模式由单个JVM上单个线程(本地模式)或四个线程(local[*]模式)运行。Standalone通常用于小规模集群或开发和测试环境。在YARN或Mesos模式下,Spark将任务提交给集群管理器,并通过管理器分配和管理资源。 总体来说,初学Spark时,我们需要了解Spark的核心组件、编程API和运行模式。熟悉这些概念以及Spark的架构,可以帮助我们更好地理解Spark和构建高效且可扩展的Spark应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Donp1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值