首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js的DOM理解

复制代码 DOM 什么是DOM 1.DOM — > Document Object Model 2.DOM定义了表示和修改文档所需的方法。...DOM对象即为宿主对象, 由浏览器厂商定义,用来操作html和xml功能的一类对象的集合。 也有人称DOM是对HTML以及XML的标准编程接口。...复制代码 DOM基本操作 1.对节点的增删改查 查看元素节点 document代表整个文档 document.getElementById() //元素id 在Ie8以下的浏览器, 不区分id大小写,而且也返回匹配...) .getElementsByClassName() // 类名 -> ie8和ie8以下的ie版本中没有,可以多个class一起 .querySelector() // css选择器 在ie7和...ie7以下的版本中没有,非实时 .querySelectorAll() // css选择器 在ie7和ie7以下的版本中没有,非实时 复制代码 DOM基本操作 遍历节点树: parentNode ->

4.2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS它DOM

    DOM:document object model。文档对象模型。它主要由许多节点。而基于JS对象的一切视角,DOM核心是节点对象和操作方法的属性。从下面三方面来介绍DOM。...三、元素尺寸和位置 通过上述CSS样式的方式,我们也是能够获取DOM中各个元素的尺寸和位置的,但有一个弊端:当元素中存在pading,margin这些样式设计时,这些方法便不能获得一些元素真正的大小和位置...JS中提供了专门儿用于获取元素尺寸和大小的方法。 实际大小:针对于元素的实际大小。主要与四个因素有关,padding。margin,border,scroll。而以下提供的几种方法,针对于不同的因素。...会有不同的结果,仅依据需求使用就可以 周边大小: 小结:DOM是JS学习的一个核心内容。...当中涉及到的元素节点的属性和基本操作也是前台页面中最重要的组成,通过这些,才干使JS中基于对象的思想发挥作用。能够说,B/S UI页面中的一切都是建立在这些元素的基础之上的。

    3.2K20

    js对象和原型、原型链的关系

    JS的原型、原型链一直是比较难理解的内容,不少初学者甚至有一定经验的老鸟都不一定能完全说清楚,更多的"很可能"是一知半解,而这部分内容又是JS的核心内容,想要技术进阶的话肯定不能对这个概念一知半解,碰到问题靠...有时候需要在两个对象之间共享属性,由于JS在设计之初没有类的概念,所以JS使用函数的prototype来处理这部分需要被共享的属性,通过函数的prototype来模拟类:当创建一个函数时,JS会自动为函数添加...对象的原型可能也是继承其他原型对象的: foo.prototype也有它的原型Object.prototype。一层一层的,以此类推,这种关系就是原型链。...一个对象是否在另一个对象的原型链上如果一个对象存在另一个对象的原型链上,我们可以说:它们是继承关系。...foo1.obkoro1和foo1.koro:返回undefined静态属性: foo.obkoro1、foo.koro函数在JS中是一等公民,它也是一个对象, 用来模拟类。

    1.5K20

    JS DOM学习笔记

    delay毫秒就调用一次method函数,相当于是计时器 4、window.clearInterval(name); //取消计时器name //setInterval(method, delay)函数和clearInterval...window.onload = function () { //...... }  //动态注册事件,窗体加载完成后执行,和body onload效果差不多 7、window.控件Id(不建议使用),推荐...支持的方法不一样 获取网页中那个元素触发了事件,在IE中使用srcElement; 在FireFox里使用target 使用Dom获取和更改网页标签元素内文本,在IE中使用innerText; 在FireFox...,解决了不同浏览器上Dom的不同 14、jQuery的ready和Dom的onload的区别:window.onload只能注册一次,是在所有的Dom元素创建完毕、图片、CSS都加载完毕后才被触发;而jQuery...的ready则是在Dom元素创建完毕后被触发,这样可以提高网页的响应速度 15、js打印一个对象的所有属性: //传入一个对象 function (swiper){ var msg = "";

    4K40

    再谈BOM和DOM(2):DOM节点层次属性选择器节点关系操作详解

    DOM模型将整个文档(XML文档和HTML文档)看成一个树形结构,并用document对象表示该文档。...DOM节点关系 nodeType 返回节点类型的数字值(1~12) nodeName 元素节点:标签名称(大写)、属性节点:属性名称、文本节点:#text、文档节点:#document nodeValue...确定节点之间的各种关系 parentNode 父节点 parentElement 父节点标签元素 childNodes 所有子节点 children 第一层子节点 firstChild 第一个子节点,...() 参照节点之前插入节点,两个参数:要插入的节点和参照节点 insertAfter() 参照节点之后插入节点,两个参数:要插入的节点和参照节点 replaceChild() 替换节点,两个参数:要插入的节点和要替换的节点...BOM和DOM(2):DOM节点层次/属性/选择器/节点关系/操作详解》, 请注明出处:https://www.zhoulujun.cn/html/webfront/SGML/xml/2020_0317

    1.2K20

    【JS】204-让虚拟DOM和DOM-diff不再成为你的绊脚石

    曾经听说很多人被问到过虚拟DOM和DOM-diff算法是如何实现的,有没有研究过?...我们虽然走的慢,但是却从未停下脚步 神奇的虚拟DOM 首先神奇不神奇的我们先不去关注,先来简单说说何为虚拟DOM 虚拟DOM简而言之就是,用JS去按照DOM结构来实现的树形结构对象,你也可以叫做DOM对象...DOM以及将创建出来的虚拟DOM渲染成真实的DOM 首先实现一下如何创建虚拟DOM,看代码: // element.js // 虚拟DOM元素的类,构建实例对象,用来描述DOMclass Element...那么,接下来进行下一步,将其渲染为真实的DOM,别犹豫,继续回到element.js文件中 渲染虚拟DOM // element.js class Element { // 省略} function...到这里就finish了,内容有些多,可能不是很好的消耗,不过没关系,就让我用最后几句话来总结一下实现的整个过程吧 四句话 我们来梳理一下整个DOM-diff的过程: 用JS对象模拟DOM(虚拟DOM)

    84240

    Event Loop 和 JS 引擎、渲染引擎的关系

    渲染引擎 渲染时会把 html、css 分别用 parser 解析成 dom 和 cssom,然后合并到一起,并计算布局样式成绝对的坐标,生成渲染树,之后把渲染树的内容复制到显存就可以由显卡来完成渲染。...如何结合 JS 引擎和渲染引擎 不管是 JS 引擎、还是渲染引擎,都比较傻(纯粹),JS 引擎只会不断执行 JS 代码,渲染引擎也是只会布局和渲染。但是要完成一个完整的网页应用,这两者都需要。...单线程 因为 javascript 最开始只是被设计用来做表单处理,那么就不会有特别大的计算量,就没有采用多线程架构,而是在一个线程内进行 dom 操作和逻辑计算,渲染和 JS 执行相互阻塞。...,不同的宿主环境有不同的需要调度的任务,所以也会有不同的设计: 浏览器里面主要是调度渲染和 JS 执行,还有 worker node 里面主要是调度各种 io 跨端引擎也是调度渲染和 JS 执行 这里我们只关心浏览器里面的...event loop 的问题 上文聊过,虽然后面加入了 worker,但是主流的方式还是 JS 计算和渲染相互阻塞,这样就导致了一个问题: 每一帧的计算和渲染是有固定频率的,如果 JS 执行时间过长,超过了一帧的刷新时间

    2.4K20

    js执行会阻塞DOM树的解析和渲染,那么css加载会阻塞DOM树的解析和渲染吗

    /h1> 假设: css加载会阻塞DOM树解析和渲染 假设结果: 在bootstrap.css还没加载完之前,下面的内容不会被解析渲染,那么我们一开始看到的应该是白屏...因为你加载css的时候,可能会修改下面DOM节点的样式,如果css加载不阻塞DOM树渲染的话,那么当css加载完之后,DOM树可能又得重新重绘或者回流了,这就造成了一些没有必要的损耗。...所以我干脆就先把DOM树的结构先解析完,把可以做的工作做完,然后等你css加载完之后,在根据最终的样式来渲染DOM树,这种做法性能方面确实会比较好一点。 3.css加载会阻塞js运行吗? ​...由上面的推论,我们可以得出,css加载不会阻塞DOM树解析,但是会阻塞DOM树渲染。那么,css加载会不会阻塞js执行呢? 同样,通过代码来验证. <!....png](/img/bVbf3O2) 结论 由上所述,我们可以得出以下结论: 1.css加载不会阻塞DOM树的解析 2css加载会阻塞DOM树的渲染 3css加载会阻塞后面js语句的执行、 因此,为了避免让用户看到长时间的白屏时间

    2.3K20

    前端Demo|JS HTML DOM基础|适合学习JS的同学

    DOM处于JavaScript语言的核心地位,如何操作 html,就是 DOM。简单的说,dom 提供了控制html的接口。 那么HTML DOM是什么呢?...HTML DOM 是 HTML 的标准对象模型和编程接口 它定义了: 作为对象的 HTML 元素 所有 HTML 元素的属性 访问所有 HTML 元素的方法 所有 HTML 元素的事件 换言之: HTML...DOM 是关于如何获取、更改、添加或删除 HTML 元素的标准。...在JS中,不夸张的说,万物即对象,而每个载入浏览器的 HTML 文档都会成为 Document 对象。Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。...innerHTML 属性,innerHTML 属性可用于获取或改变任何 HTML 元素,包括 和 E N D

    1.6K20

    js对象(BOM部分DOM部分)

    JS总体包括ECMAScript,DOM,BOM三个部分,但是能够和浏览器进行交互的只有DOM和BOM,那么到底什么是DOM和BOM呢 概念 BOM(Browser Object Model)是指浏览器对象模型...接下来要讲的HTML DOM 的 document 也是 window 对象的属性之一。...DOM(Document Object Model)是一套对文档的内容进行抽象和概念化的方法。...HTML DOM 模型被构造为对象的树 DOM树 DOM标准规定HTML文档中的每个成分都是一个节点(node): 文档节点(document对象):代表整个文档 元素节点(element 对象):代表一个元素...根据class属性获取 document.getElementsByTagName 根据标签名获取标签合集 注意: 涉及到DOM操作的JS代码应该放在文档的哪个位置。

    4.3K20
    领券