首页
学习
活动
专区
圈层
工具
发布

如何更优地去创建DOM元素

本文作者:IMWeb yuchenli 原文出处:IMWeb社区 未经同意,禁止转载 如何更优地去创建DOM元素 创建DOM元素是最为基本的DOM操作,这里先举个栗子 这里先使用createElement...这里简单地通过createElement创建DOM是存在比较严重的性能问题的: 1、createElement本身就是不小的性能开支 2、 每次创建li元素都换插入到DOM中,会引起多次重排和重绘。...innerHTM 对面上面那种问题,可能就会想到通过innterHTML方式去创建DOM元素 这里先举个栗子: var str = ''; for (t = 0; t < num; t++) {...cloneNode cloneNode是用于克隆节点的,相比直接调用createElement创建DOM元素而言,它所花费的开销会更小些,就好比:读书的时候,抄作业要比做作业的容易的多。...它被当做一个轻量版的 Document使用,用于存储已排好版的或尚未打理好格式的XML片段。

2.5K10

DOM元素定位

, 16 2月 2021 作者 847954981@qq.com 前端学习, 我的编程之路 DOM元素定位 在HTML中有许多如图片等的DOM元素,在网页下拉移动中,DOM元素的位置定位通常通过 position...属性来完成 在一般情况下我们DOM元素的默认position的值为 static 除此之外position还拥有 relative(相对定位) absolute(绝对定位) fixed(固定定位) sticky...,即原本DOM元素下方的元素会向上占住原本DOM元素的位置,类似于网页新开了一个图层的效果。...固定定位 fixed fixed原理很简单,就是讲DOM元素固定在整个页面某一位置不会随着下拉页面而改动,类似一个图层放置在那里。...可以利用如 right:50px 等来调节位置 粘性定位 sticky 这个简单说就是当页面下拉到DOM元素到达了设定的位置,DOM元素将不会再随下拉移动,效果如页面内图片 顺便一提,如前面所说,网页存在类似图层一说

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

    【Web APIs】DOM 文档对象模型 ① ( DOM 相关概念 - DOM 文档、DOM 树、DOM 节点 | 根据元素 ID 获取 DOM 元素 - getElementById 函数 )

    、DOM 树、DOM 节点 DOM 文档 : 一个 HTML 页面就是一个文档 , DOM 中使用 document 表示 ; DOM 树 : Document Object Model Tree ,...是 由 DOM 节点 组成的树形结构 , 代表了 HTML 网页文件的 层次结构 ; DOM 文档对象模型 将 HTML 文档 在内存中生成 为一个 DOM 树 ; 下图是 使用 DOM 文档对象模型...DOM 元素的方法 : 根据 元素 ID 获取 DOM 元素 , getElementById 函数 ; 根据 标签名 称获取 DOM 元素 , getElementsByTagName 函数 ; 根据...函数 ; 特殊 DOM 元素获取 ; 2、根据元素 ID 获取 DOM 元素 - getElementById 函数 根据元素 ID 获取 DOM 元素 , 调用 Web APIs 中提供的 getElementById...'); 上述调用示例中 , id 是 字符串变量 , 注意要使用 双引号 或 单引号 , 要获取的 HTML 元素的 ID ; element 返回值 是 获取的 DOM 元素 Element 类型对象

    1.3K10

    新手如何在 ES6 如何操作HTML DOM元素?

    ES6 HTML DOM DOM代表文档对象**模型。HTML 页面在浏览器中呈现。浏览器将从网络服务器下载的页面中包含的所有元素组装到其内存中。...支持 JavaScript 的浏览器能够在 HTML 页面在浏览器中呈现之后识别该页面中的各个对象,因为支持 JavaScript 的浏览器可以识别并使用 DOM。因此,允许随意控制对象的功能。...它还有自己的多个元素。我们这里只讨论表单。 表单: DOM 层次结构继续向下包含表单的各个元素 DOM 类别: JavaScript 支持三种 DOM 类型,但我们仅讨论适用于 ES6 的类型。...**Legacy DOM:**这是早期版本的 JavaScript 使用的模型。该模型提供只读属性,例如标题、URL 等。它还提供有关整个文档的 LastModified 信息。...IE4 DOM 中的文档属性: activeElement:指当前活动的输入元素。 document.activeElement all[]: 文档中所有元素对象的可索引数组。

    77620

    DOM概述 选取文档元素

    脚本化文档 客户端js的存在使得静态的html文档变成了可交付式的web应用 DOM概述 文档对象(DOM)是表示和操作html和xml文档内容的基础api。 元素 通过ID选取元素 举一个栗子,通过ID查找多个元素 /* * 函数接收任意多的字符串参数 * 每个参数将当做元素的id传给document.getElementById() * 返回一个对象...("span"); 这样能获取第一个p元素里的所有的span元素 另外document还有两个属性,分别是特殊的body,以及head元素,这两个元素如果源代码未包含,其浏览器会隐式的创建他们,以及documentElement...注意,保存的不是快照,伴随着html中的DOM的更新,属于实时操作的,这一点灰常有用 如果在一个没有div中的有一个该方法,如果页面动态加载进的div元素,其中的length会自动更新加1,也会自动成为...0) // 使用浅拷贝,生成副本对副本进行操作 再次使用 Array.prototype.splice() 执行删除操作,但是其真正的节点不会删除,因为是一个副本 下面是通过css选取元素

    1.3K60

    DOM 元素的循环遍历

    = document.querySelectorAll('.title') 一般循环 get 方式 get 方式获取的 dom 元素,仅可使用==for-in、for-of、for==循环 for(let...('popo') 获取 name 属性为 'popo' 的 dom 元素(若多个元素有相同的 name 属性,返回第一个) for-of、for 循环可获取每个 dom 元素: for(let val...(每个dom元素) for(let i = 0; i < a.length; i++) { console.log(a[i]) } // dom // ......(每个dom元素) query 方式 query 方式获取的 dom 元素,可使用==forEach、for-in、for-of、for==循环 forEach、for-of、for 循环的结果无差别...NodeIterator 对象,可以对 DOM 树进行深度优先的搜索 创建 NodeIterator 对象,需要使用 document 对象的 createNodeIterator 方法,该方法接收四个参数

    7.7K60

    JavaScript DOM元素尺寸和位置

    三大点: 1.获取元素CSS大小 2.获取元素实际大小 3.获取元素周边大小 一.获取元素CSS大小 1.通过style内联获取元素的大小 var box = document.getElementById...总结:以上的三种CSS获取元素大小的方法,只能获取元素的CSS大小,却无法获取元素本身实际的大小。比如加上了内边距、滚动条、边框之类的。...如果是内联元素(inline)或者没有设置大小的元素就尤为麻烦,所以,建议使用的时候注意。...如果两个元素嵌套,如果上父元素没有使用定位position:absolute,那么offsetParent将返回body对象或html对象。...box.offsetTop + box.offsetParent.offsetTop;//只有两层的情况下 如果多层的话,就必须使用循环或递归。

    3.3K70

    dom 元素自定义指令

    如果感觉 vue 提供的功能不足够,需要获取 dom 元素进行底层操作,就可以自定义指令 在初始化 vue 实例的时候,参数对象里面可以添加一个 directives 属性,为 vue 增加自定义指令。...写好一个指令的方法之后,就可以像 v-html 等的内置指令一样使用了。...标签使用的时候需要添加 v- 前缀 指令内触发的函数名不能乱起,按固定写就好了,感兴趣可以查文档看看其他函数名 函数接收的第一个参数是元素本身。...directives: { focus: { // 指令的定义,这个 inserted 是固定写法,意思是带有这个指令的 dom 元素被插入的时候,触发这个方法 // 还有其他一些可选写法...,感兴趣可以看文档 inserted: function (el) { el.children[0].focus() } } } 2、使用指令 <input v-focus

    1.1K20

    绕过React框架修改Dom元素

    如果是原生的页面,使用element.value赋值就可以实现,比较简单,但是如果是框架实现的页面,例如React框架,就会遇到一个困难,就是你修改完了Dom元素的值再去触发了React框架重新渲染就会让...React框架自身的state输出到Dom元素中,导致修改的值被回滚了。...那如何修改React框架内保存的状态呢?解决这里本质上,是需要解决React的state需要同步进行更改,如果只是修改Dom元素,就迟早会被React回滚回来。...它主要有两个属性:value:存储表单元素的当前值。isMounted:表示组件是否已经挂载到 DOM 上。React 使用 _valueTracker 来优化性能和确保状态的一致性。...在 React 17 及更高版本中,_valueTracker 已经被移除,React 使用其他方式来跟踪和管理表单元素的值。

    60311
    领券