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

如何更优地去创建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元素而言,它所花费的开销会更小些,就好比:读书的时候,抄作业要比做作业的容易的多。...那么还有没有更快的方式去创建DOM元素呢?接下来先介绍一个东西DocumentFragment DocumentFragment DocumentFragment是示一个没有父级文件的最小文档对象。

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

    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元素将不会再随下拉移动,效果如页面内图片 顺便一提,如前面所说,网页存在类似图层一说

    98230

    JavaScript 学习-34.HTML DOM 创建插入删除替换元素

    前言 HTML DOM 可以创建一个新元素,并插入到指定元素的位置 createElement 创建元素 document.createElement() 可以创建一个元素 document.createTextNode...() 创建一个文本节点 appendChild() 方法可向节点的子节点列表的末尾添加新的子节点。...DocumentFragment 节点代表一个文档的片段,本身就是一个完整的 DOM 树形结构。 它没有父节点,parentNode 返回 null ,但是可以插入任意数量的子节点。...它不属于当前文档,操作 DocumentFragment 节点,要比直接操作 DOM 树快得多。 它一般用于构建一个 DOM 结构,然后再插入当前文档。...添加到div子元素,p标签前面 这是文本内容 // 创建元素节点 btn = document.createElement

    2.7K30

    jQuery操作DOM元素

    最常见的场景莫过DOM元素操作和前端页面使用AJAX向服务器发送请求。...的标签,返回类型是DOM元素数组 id $('#value'),选取页面上id=value的标签 $('[name]'),选取带有name属性的标签,返回类型是DOM元素数组 $('[name="tag...="tag"]'),选取name不等于tag的标签,返回类型是DOM元素数组 $('[href=".jpg"]'),选取所有href属性值以 ".jpg" 结尾的标签,返回类型是DOM元素数组 --...tr元素,返回类型是DOM元素数组 :odd $("tr:odd"),选取页面上索引为奇数的tr元素,返回类型是DOM元素数组 :not() $("input:not(:empty)"),所有不为空的...+ conditions); 元素操作 说明 hide() 隐藏元素 show() 显示元素 $('') 创建p元素 append() 向元素末尾添加子元素 appendTo

    2.7K40

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

    DOM 节点 都代表文档中的一个部分 , 如 : 元素、属性或文本 , 并且这些节点以特定的关系相互连接 , 形成一个完整的树状图 ; 二、获取 DOM 元素 1、获取 DOM 元素的常用方法 获取...DOM 元素的方法 : 根据 元素 ID 获取 DOM 元素 , getElementById 函数 ; 根据 标签名 称获取 DOM 元素 , getElementsByTagName 函数 ; 根据...类名 称获取 DOM 元素 , getElementsByClassName 函数 ; 通过 HTML5 新方法 获取 DOM 元素 ; querySelector 函数 ; querySelectorAll...函数 ; 特殊 DOM 元素获取 ; 2、根据元素 ID 获取 DOM 元素 - getElementById 函数 根据元素 ID 获取 DOM 元素 , 调用 Web APIs 中提供的 getElementById..., 在 JavaScript 脚本中 , 可以通过 var element = document.getElementById("text"); 代码 获取 上述 DOM 元素 ; <!

    14310

    DOM概述 选取文档元素

    脚本化文档 客户端js的存在使得静态的html文档变成了可交付式的web应用 DOM概述 文档对象(DOM)是表示和操作html和xml文档内容的基础api。 <!...选取文档元素 通过ID选取元素 举一个栗子,通过ID查找多个元素 /* * 函数接收任意多的字符串参数 * 每个参数将当做元素的id传给document.getElementById() * 返回一个对象...("span"); 这样能获取第一个p元素里的所有的span元素 另外document还有两个属性,分别是特殊的body,以及head元素,这两个元素如果源代码未包含,其浏览器会隐式的创建他们,以及documentElement...e.innerHTML; // 返回序列化过的html代码,该方法继承自Element,所有Document对象的方法都基于其,因为同样是document继承来的,所以具有innerHTML方法 } ) // 创建一个数组...,并把该数组的元素传入回调函数中进行处理 注意,保存的不是快照,伴随着html中的DOM的更新,属于实时操作的,这一点灰常有用 如果在一个没有div中的有一个该方法,如果页面动态加载进的div元素,其中的

    1K60

    DOM 元素的循环遍历

    博客地址:https://ainyi.com/89 获取 DOM 元素的几种方式 get 方式: getElementById getElementsByTagName getElementsByClassName...('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 对象,需要使用 document 对象的 createNodeIterator 方法,该方法接收四个参数: root:搜索开始的节点 whatToShow

    6.4K60

    JavaScript DOM元素尺寸和位置

    三大点: 1.获取元素CSS大小 2.获取元素实际大小 3.获取元素周边大小 一.获取元素CSS大小 1.通过style内联获取元素的大小 var box = document.getElementById...总结:以上的三种CSS获取元素大小的方法,只能获取元素的CSS大小,却无法获取元素本身实际的大小。比如加上了内边距、滚动条、边框之类的。...二.获取元素实际大小 1.clientWidth和clientHeight 这组属性可以获取元素可视区的大小,可以得到元素内容及内边距所占据的空间大小。...; 3.增加外边据,无变化; 4.增加滚动条,无变化,不会减小; PS:对于元素大小的获取,一般是块级(block)元素并且以设置了CSS大小的元素较为方便。...如果是内联元素(inline)或者没有设置大小的元素就尤为麻烦,所以,建议使用的时候注意。

    2.8K70
    领券